C/Przykłady z komentarzem: Różnice pomiędzy wersjami
linki do definicji funkcji (trzeba nabić sobie ranking Google, nie ;-), poprawa komentarzy |
{{poprawić|zamienić liczby zespolone na zwykłe}} |
||
Linia 2: | Linia 2: | ||
=== Losowe liczby zespolone === |
=== Losowe liczby zespolone === |
||
{{poprawić|zamienić liczby zespolone na zwykłe; liczby zespolone nic tu nie wnoszą a tylko potęgują zamieszanie, ten program po prostu generuje tabliczkę liczb losowych}} |
|||
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. |
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. |
Program napisany i skompilowany został w środowisku GNU/Linux. |
Wersja z 14:34, 1 paź 2006
Losowe liczby zespolone
Szablon:Poprawić 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; }