C/Przykłady z komentarzem: Różnice pomiędzy wersjami

Z Wikibooks, biblioteki wolnych podręczników.
< C
Usunięta treść Dodana treść
GDR! (dyskusja | edycje)
Wersja polegająca na tym że rozmiar short int to zawsze 16 bitów była niedopuszczalna
GDR! (dyskusja | edycje)
m →‎Zamiana liczb dziesiętnych na liczby w systemie dwójkowym: Wyświetlanie max dopuszczalnej wartości
Linia 60: Linia 60:
<pre>
<pre>
#include <stdio.h>
#include <stdio.h>
#include <limits.h>


void dectobin (unsigned short a)
void dectobin (unsigned short a)
Linia 80: Linia 81:
unsigned short a;
unsigned short a;


printf ("Podaj liczbę: ");
printf ("Podaj liczbę od 0 do %d: ", USHRT_MAX);
scanf ("%d", &a);
scanf ("%d", &a);
printf ("%d(10) = ", a);
printf ("%d(10) = ", a);

Wersja z 17:16, 17 wrz 2006

< Programowanie:C

Losowe liczby zespolone

Poniższy program generuje wiersz po wierszu macierz o określonych przez użytkownika wymiarach, zawierającą losowe liczby zespolone. Każdy wygenerowany wiersz macierzy zapisywany jest w pliku tekstowym o wprowadzonej przez użytkownika nazwie. W pierwszym wierszu pliku wynikowego zapisano wymiary utworzonej macierzy. Program napisany i skompilowany został w środowisku GNU/Linux.

 #include <stdio.h>
 #include <stdlib.h>  // dla funkcji rand() oraz srand()
 #include <time.h>	// dla funkcji time()
 
 main()
 {
   int i, j, n, m;
   float re, im;
   FILE *fp;
   char fileName[128];
 
   printf("Wprowadz nazwe pliku wynikowego..\n");
   scanf("%s",&fileName);
 
   printf("Wprowadz po sobie liczbe wierszy i kolumn macierzy oddzielone spacją..\n");
   scanf("%d %d", &n, &m);
 
            /* jezeli byl blad w otwieraniu pliku i go nie otwarto,
             wówczas funkcja fclose(fp) wywołana na końcu programu zgłosi błąd
             wykonania i wysypie nam program z działania, stąd musimy umieścić
             warunek, który w kontrolowany sposób zatrzyma program (funkcja exit;)
            */
   if ( (fp = fopen(fileName, "w")) == NULL )  
   {
     puts("Otwarcie pliku nie jest mozliwe!");
     exit;    /*  jeśli w procedurze glownej
               to piszemy bez nawiasow */
   }
 
   else  { puts("Plik otwarty prawidłowo..");  }
   
   fprintf(fp, "%d %d\n", n, m);
           /* w pierwszym wierszu umieszczono wymiary macierzy */
 
   srand( (unsigned int) time(0) );
   for (i=1; i<=n; i++)
   {
     for (j=1; j<=m; j++)
     {
       re = ((rand() % 200)-100)/ 10.0;
       im = ((rand() % 200)-100)/ 10.0;
       fprintf(fp,"%.1f %.1f", re, im );
       if (j!=m) fprintf(fp,"    ");
     }
   fprintf(fp,"\n");
   }  
   fclose(fp);
   return 0;
 }

Zamiana liczb dziesiętnych na liczby w systemie dwójkowym

Zajmijmy się teraz innym zagadnieniem. Wiemy, że komputer zapisuje wszystkie liczby w postaci binarnej (czyli za pomocą jedynek i zer). Spróbujmy zatem zamienić liczbę, zapisaną w "naszym" dziesiątkowym systemie na zapis binarny. Uwaga: Program działa jedynie dla liczb od 0 do maksymalnej wartości którą może przyjąć typ unsigned short int w twoim kompilatorze.

#include <stdio.h>
#include <limits.h>

void dectobin (unsigned short a)
{
  int licznik;      

  /* 8 to ilość bitów w bajcie */
  licznik = 8 * sizeof(a);
  while(--licznik >= 0)
  {
   if ((a >> licznik) & 1) 
    printf ("1");
   else 
    printf ("0");
   }
}

int main ()
{
  unsigned short a;

  printf ("Podaj liczbę od 0 do %d: ", USHRT_MAX);
  scanf ("%d", &a);
  printf ("%d(10) = ", a);
  dectobin(a);
  printf ("\n");

  return 0;
}


< Programowanie:C