C/Przykłady z komentarzem: Różnice pomiędzy wersjami
< C
Usunięta treść Dodana treść
Wersja polegająca na tym że rozmiar short int to zawsze 16 bitów była niedopuszczalna |
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
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; }