int _tmain(int argc, _TCHAR* argv[])
{
char str[20],str2[20];
cout<<str<<endl; //由於分配了空間,沒有寫入資料,在輸出地時候讀沒有寫入資料的地址就回出現亂碼
for(int i=0;i<20;i++)
{
str[i]='a';
//if(i==10)
//{
// str[10]='\0';//字串遇到了\0,就會結束,所以strlen(str)=10
//}
}
str[19]='\0';//結束字串,沒有這一句就回出現亂碼
strcpy(str2,str);//將一個字串賦給列一個相等容量的字串是會出現亂碼的,因為字串的最後一位必須是\0
cout<<str<<" , "<<sizeof(str)<<" , "<<strlen(str)<<" , "<<str2<<endl;
int k = 5;
k = k + (++k);
cout<<k<<endl;
int b1;
cin>>b1;
return 0;
}
輸出結果如下:
char str[20];
定義一個長度為20的字元數組,系統會分配20個連續的空間給str;開始的時候每個空間裡面都沒有值;
str指向數組的第一個空間,str相當於一個常量指標,所以不能寫str=?;
sizeof(str)表式str所佔的空間長度,char str[20]表示長度為20,也就是說sizeof(str)的值在定義的時候就已經定了,
就是字元創數組的長度。
strlen(str)表示str中字元的個數,這裡有19個,最後一個\0不算。
int k = 5;
k = k + (++k);
最後k=12;這個的確不太好理解
理解:可以這樣理解i++和++i:
對於一個運算式;如果有++i;就相當於在運算式之前加入一行代碼i=i+1;
同理有i++;相當於在運算式後面加入一行代碼i=i+1
int k = 5; k = k + (++k);相當於int k=5;k=k+1;k=k+k;
測試題:遞迴實現猴子偷桃問題
//猴子吃桃問題。猴子第一天摘下若干個桃子,當即吃了一半,還不過癮,又多吃了一個。
//第二天又將剩下的桃子吃掉一半,又多吃一個。以後每天都吃了前一天剩下的一半零一個。
//到第10天,只剩下一個桃子了。編程試求第一天共摘了多少桃子。
int Eat(int currentCount,int i)
{
if(i==10)
{
return currentCount;
}else{
currentCount=(currentCount+1)*2;
i++;
}
return Eat(currentCount,i);
}
cout<<Eat(1,10)<<endl;
得出第一天摘了1534個桃子。
最後一招猴子偷桃,竟然偷了1534個。