C++ 數字
通常,當我們需要用到數字時,我們會使用原始的數據類型,如 int、short、long、float 和 double 等等。這些用於數字的數據類型,其可能的值和數值範圍,我們已經在 C++ 數據類型一章中討論過。
C++ 定義數字
我們已經在之前章節的各種實例中定義過數字。下麵是一個 C++ 中定義各種類型數字的綜合實例:
實例
#include <iostream>
using namespace std;
int main ()
{
// 數字定義
short s;
int i;
long l;
float f;
double d;
// 數字賦值
s = 10;
i = 1000;
l = 1000000;
f = 230.47;
d = 30949.374;
// 數字輸出
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;
}
當上面的代碼被編譯和執行時,它會產生下列結果:
short s :10 int i :1000 long l :1000000 float f :230.47 double d :30949.4
C++ 數學運算
在 C++ 中,除了可以創建各種函數,還包含了各種有用的函數供您使用。這些函數寫在標準 C 和 C++ 庫中,叫做內置函數。您可以在程式中引用這些函數。
C++ 內置了豐富的數學函數,可對各種數字進行運算。下表列出了 C++ 中一些有用的內置的數學函數。
為了利用這些函數,您需要引用數學頭檔 <cmath>。
序號 | 函數 & 描述 |
---|---|
1 | double cos(double); 該函數返回弧度角(double 型)的余弦。 |
2 | double sin(double); 該函數返回弧度角(double 型)的正弦。 |
3 | double tan(double); 該函數返回弧度角(double 型)的正切。 |
4 | double log(double); 該函數返回參數的自然對數。 |
5 | double pow(double, double); 假設第一個參數為 x,第二個參數為 y,則該函數返回 x 的 y 次方。 |
6 | double hypot(double, double); 該函數返回兩個參數的平方總和的平方根,也就是說,參數為一個直角三角形的兩個直角邊,函數會返回斜邊的長度。 |
7 | double sqrt(double); 該函數返回參數的平方根。 |
8 | int abs(int); 該函數返回整數的絕對值。 |
9 | double fabs(double); 該函數返回任意一個浮點數的絕對值。 |
10 | double floor(double); 該函數返回一個小於或等於傳入參數的最大整數。 |
下麵是一個關於數學運算的簡單實例:
實例
#include <iostream>
#include <cmath>
using namespace std;
int main ()
{
// 數字定義
short s = 10;
int i = -1000;
long l = 100000;
float f = 230.47;
double d = 200.374;
// 數學運算
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;
}
當上面的代碼被編譯和執行時,它會產生下列結果:
sin(d) :-0.634939 abs(i) :1000 floor(d) :200 sqrt(f) :15.1812 pow( d, 2 ) :40149.7
C++ 亂數
在許多情況下,需要生成亂數。關於亂數生成器,有兩個相關的函數。一個是 rand(),該函數只返回一個偽亂數。生成亂數之前必須先調用 srand() 函數。
下麵是一個關於生成亂數的簡單實例。實例中使用了 time() 函數來獲取系統時間的秒數,通過調用 rand() 函數來生成亂數:
實例
#include <iostream>
#include <ctime>
#include <cstdlib>
using namespace std;
int main ()
{
int i,j;
// 設置種子
srand( (unsigned)time( NULL ) );
/* 生成 10 個亂數 */
for( i = 0; i < 10; i++ )
{
// 生成實際的亂數
j= rand();
cout <<"亂數: " << j << endl;
}
return 0;
}
當上面的代碼被編譯和執行時,它會產生下列結果:
亂數: 1748144778 亂數: 630873888 亂數: 2134540646 亂數: 219404170 亂數: 902129458 亂數: 920445370 亂數: 1319072661 亂數: 257938873 亂數: 1256201101 亂數: 580322989