技術(shù)交流QQ群:1027579432舅踪,歡迎你的加入!
1.Cpp中的數(shù)字
- 當(dāng)需要用到數(shù)字時选侨,我們會使用原始的數(shù)據(jù)類型掖鱼,如int、short援制、long戏挡、float和double等等。這些用于數(shù)字的數(shù)據(jù)類型晨仑,其可能的值和數(shù)值范圍褐墅,已經(jīng)在C++數(shù)據(jù)類型中討論過拆檬。
- 1.1 定義數(shù)字
int main(){
// 數(shù)字定義
short s;
int i;
long l;
float f;
double d;
// 數(shù)字賦值
s = 10;
i = 1000;
l = 1000000;
f = 230.45;
d = 4545.398;
cout << "s = " << s << endl;
cout << "i = " << i << endl;
cout << "l = " << l << endl;
cout << "f = " << f << endl;
cout << "d = " << d << endl;
return 0;
}
2.Cpp中的數(shù)學(xué)運(yùn)算
- 在C++中,除了可以創(chuàng)建各種函數(shù)掌栅,還包含了各種有用的函數(shù)供你使用秩仆。這些函數(shù)寫在標(biāo)準(zhǔn)C和C++庫中,叫做內(nèi)置函數(shù)猾封,可以在程序中引用這些函數(shù)澄耍。C++內(nèi)置了豐富的數(shù)學(xué)函數(shù),可對各種數(shù)字進(jìn)行運(yùn)算晌缘。下表列出了C++中一些有用的內(nèi)置的數(shù)學(xué)函數(shù)齐莲,為了利用這些函數(shù),需要引用數(shù)學(xué)頭文件 <cmath>磷箕。
內(nèi)置數(shù)學(xué)函數(shù).png
int main(){
// 數(shù)字定義
short s;
int i;
long l;
float f;
double d;
// 數(shù)字賦值
s = 10;
i = - 1000;
l = 1000000;
f = 230.45;
d = 4545.398;
cout << "s = " << s << endl;
cout << "i = " << i << endl;
cout << "l = " << l << endl;
cout << "f = " << f << endl;
cout << "d = " << d << endl;
// 數(shù)學(xué)運(yùn)算
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;
}
3.Cpp中的隨機(jī)數(shù)
- 在許多情況下选酗,需要生成隨機(jī)數(shù)。關(guān)于隨機(jī)數(shù)生成器岳枷,有兩個相關(guān)的函數(shù)芒填。一個是rand(),該函數(shù)只返回一個偽隨機(jī)數(shù)空繁。生成隨機(jī)數(shù)之前必須先調(diào)用srand()函數(shù)殿衰。
// 隨機(jī)數(shù)
int m, n;
// 設(shè)置隨機(jī)數(shù)種子
srand((unsigned)time(NULL)); // time()用來獲取系統(tǒng)時間的秒數(shù),通過調(diào)用rand()函數(shù)來生成隨機(jī)數(shù)
// 生成10個隨機(jī)數(shù)
for(m = 0; m < 10; m++){
// 生成實際的隨機(jī)數(shù)
n = rand();
cout << "隨機(jī)數(shù): " << n << endl;
}
- srand()函數(shù)是隨機(jī)數(shù)生成器的初始化函數(shù),詳細(xì)介紹如下:
- 函數(shù)原型: void srand(unsigned seed);
- 用法: 它需要提供一個種子盛泡,這個種子會對應(yīng)一個隨機(jī)數(shù)闷祥,如果使用相同的種子,后面的rand()函數(shù)會出現(xiàn)一樣的隨機(jī)數(shù)傲诵。如:srand(1);直接使用1來初始化種子凯砍。為了防止隨機(jī)數(shù)每次重復(fù),常常使用系統(tǒng)時間來初始化拴竹,即用time函數(shù)來獲得系統(tǒng)時間悟衩,它的返回值為從 00:00:00 GMT, January 1, 1970 到現(xiàn)在所持續(xù)的秒數(shù),然后將time_t型數(shù)據(jù)轉(zhuǎn)化為(unsigned)型再傳給 srand 函數(shù)栓拜,即:srand((unsigned) time(&t)); 還有常用的方法:不需要定義time_t型的t變量,即:srand((unsigned) time(NULL)); 直接傳入一個空指針局待,因為你的程序中往往并不需要經(jīng)過參數(shù)獲得的t數(shù)據(jù)。
const int MAX = 10;
int number[MAX] = {0};
int k;
srand((unsigned) time(NULL)); // 播種子
for (k = 0; k < MAX; k++){
number[k] = rand() % 100; // 產(chǎn)生0-100內(nèi)的隨機(jī)數(shù)
cout << "number[" << k << "] = " << number[k] << endl;
}
- 補(bǔ)充說明:
- rand隨機(jī)數(shù)產(chǎn)生的范圍:在標(biāo)準(zhǔn)C庫中函數(shù)rand()可以生成0~RAND_MAX之間的一個隨機(jī)數(shù)菱属,其中RAND_MAX是stdlib.h中定義的一個整數(shù),它與系統(tǒng)有關(guān)舰罚,至少是32767纽门。
- 使用rand()和srand()產(chǎn)生指定范圍內(nèi)的隨機(jī)整數(shù)的方法: 模除+加法,如果要產(chǎn)生[m,n]范圍內(nèi)的隨機(jī)數(shù)num,可用,int num = rand() % (n-m+1)+m;即(rand()%[區(qū)間內(nèi)數(shù)的個數(shù)]+區(qū)間的起點值)
#define random(x) (rand() % x)
srand((int)time(0));
for (int a = 0; a < 10; a++){
cout << random(100) << endl; // 輸出0-100內(nèi)的隨機(jī)數(shù)
}
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者