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

Z Wikibooks, biblioteki wolnych podręczników.
< C
Usunięta treść Dodana treść
Derbeth (dyskusja | edycje)
{{poprawić|zamienić liczby zespolone na zwykłe}}
Kj (dyskusja | edycje)
liczby zespolone -> "normalne" ;-)
Linia 1: Linia 1:
<small>< [[Programowanie:C]]</small>
<small>< [[Programowanie:C]]</small>


=== Losowe liczby zespolone ===
=== Liczby losowe ===
Poniższy program generuje wiersz po wierszu macierz o określonych przez użytkownika wymiarach, zawierającą losowo wybrane liczby. 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.
{{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.
Program napisany i skompilowany został w środowisku GNU/Linux.
Program napisany i skompilowany został w środowisku GNU/Linux.


Linia 13: Linia 12:
{
{
int i, j, n, m;
int i, j, n, m;
float re, im;
float re;
FILE *fp;
FILE *fp;
char fileName[128];
char fileName[128];
Linia 46: Linia 45:
{
{
re = ((rand() % 200)-100)/ 10.0;
re = ((rand() % 200)-100)/ 10.0;
im = ((rand() % 200)-100)/ 10.0;
fprintf(fp,"%.1f", re );
fprintf(fp,"%.1f %.1f", re, im );
if (j!=m) fprintf(fp," ");
if (j!=m) fprintf(fp," ");
}
}

Wersja z 15:15, 1 paź 2006

< Programowanie:C

Liczby losowe

Poniższy program generuje wiersz po wierszu macierz o określonych przez użytkownika wymiarach, zawierającą losowo wybrane liczby. 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;
  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;
      fprintf(fp,"%.1f", re );
      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