Liczby w C ++

Zwykle, gdy pracujemy z Numbers, używamy prymitywnych typów danych, takich jak int, short, long, float i double itp. Typy danych liczbowych, ich możliwe wartości i zakresy liczb zostały wyjaśnione podczas omawiania typów danych w języku C ++.

Definiowanie liczb w C ++

Zdefiniowałeś już liczby w różnych przykładach podanych w poprzednich rozdziałach. Oto kolejny skonsolidowany przykład definiujący różne typy liczb w C ++ -

#include <iostream>
using namespace std;
 
int main () {
   // number definition:
   short  s;
   int    i;
   long   l;
   float  f;
   double d;
   
   // number assignments;
   s = 10;      
   i = 1000;    
   l = 1000000; 
   f = 230.47;  
   d = 30949.374;
   
   // number printing;
   cout << "short  s :" << s << endl;
   cout << "int    i :" << i << endl;
   cout << "long   l :" << l << endl;
   cout << "float  f :" << f << endl;
   cout << "double d :" << d << endl;
 
   return 0;
}

Kiedy powyższy kod jest kompilowany i wykonywany, daje następujący wynik -

short  s :10
int    i :1000
long   l :1000000
float  f :230.47
double d :30949.4

Operacje matematyczne w C ++

Oprócz różnych funkcji, które możesz tworzyć, C ++ zawiera również przydatne funkcje, których możesz użyć. Te funkcje są dostępne w standardowych bibliotekach C i C ++ i są wywoływanebuilt-inFunkcje. Są to funkcje, które można włączyć do programu, a następnie użyć.

C ++ ma bogaty zestaw operacji matematycznych, które można wykonać na różnych liczbach. Poniższa tabela zawiera listę przydatnych wbudowanych funkcji matematycznych dostępnych w C ++.

Aby skorzystać z tych funkcji, musisz dołączyć plik nagłówkowy matematyki <cmath>.

Sr.No Funkcja i cel
1

double cos(double);

Ta funkcja przyjmuje kąt (jako podwójny) i zwraca cosinus.

2

double sin(double);

Ta funkcja przyjmuje kąt (jako podwójny) i zwraca sinus.

3

double tan(double);

Ta funkcja przyjmuje kąt (jako podwójny) i zwraca styczną.

4

double log(double);

Ta funkcja przyjmuje liczbę i zwraca logarytm naturalny tej liczby.

5

double pow(double, double);

Pierwsza to liczba, którą chcesz podbić, a druga to moc, którą chcesz podbić

6

double hypot(double, double);

Jeśli przekażesz tej funkcji długość dwóch boków trójkąta prostokątnego, zwróci ona długość przeciwprostokątnej.

7

double sqrt(double);

Przekazujesz tej funkcji liczbę, która daje pierwiastek kwadratowy.

8

int abs(int);

Ta funkcja zwraca wartość bezwzględną przekazanej do niej liczby całkowitej.

9

double fabs(double);

Ta funkcja zwraca wartość bezwzględną dowolnej przekazanej do niej liczby dziesiętnej.

10

double floor(double);

Znajduje liczbę całkowitą, która jest mniejsza lub równa przekazanemu argumentowi.

Poniżej znajduje się prosty przykład pokazujący kilka operacji matematycznych -

#include <iostream>
#include <cmath>
using namespace std;
 
int main () {
   // number definition:
   short  s = 10;
   int    i = -1000;
   long   l = 100000;
   float  f = 230.47;
   double d = 200.374;

   // mathematical operations;
   cout << "sin(d) :" << sin(d) << endl;
   cout << "abs(i)  :" << abs(i) << endl;
   cout << "floor(d) :" << floor(d) << endl;
   cout << "sqrt(f) :" << sqrt(f) << endl;
   cout << "pow( d, 2) :" << pow(d, 2) << endl;
 
   return 0;
}

Kiedy powyższy kod jest kompilowany i wykonywany, daje następujący wynik -

sign(d)     :-0.634939
abs(i)      :1000
floor(d)    :200
sqrt(f)     :15.1812
pow( d, 2 ) :40149.7

Losowe liczby w C ++

Istnieje wiele przypadków, w których będziesz chciał wygenerować liczbę losową. Istnieją dwie funkcje, które musisz wiedzieć o generowaniu liczb losowych. Pierwsza torand(), ta funkcja zwróci tylko liczbę pseudolosową. Aby to naprawić, najpierw wywołaj pliksrand() funkcjonować.

Poniżej znajduje się prosty przykład generowania kilku liczb losowych. Ten przykład wykorzystujetime() funkcja, aby uzyskać liczbę sekund czasu systemowego, aby losowo zapełnić funkcję rand () -

#include <iostream>
#include <ctime>
#include <cstdlib>

using namespace std;
 
int main () {
   int i,j;
 
   // set the seed
   srand( (unsigned)time( NULL ) );

   /* generate 10  random numbers. */
   for( i = 0; i < 10; i++ ) {
      // generate actual random number
      j = rand();
      cout <<" Random Number : " << j << endl;
   }

   return 0;
}

Kiedy powyższy kod jest kompilowany i wykonywany, daje następujący wynik -

Random Number : 1748144778
Random Number : 630873888
Random Number : 2134540646
Random Number : 219404170
Random Number : 902129458
Random Number : 920445370
Random Number : 1319072661
Random Number : 257938873
Random Number : 1256201101
Random Number : 580322989