題目要求
以下程序運行後的輸出結果是 。
main()
{ int i,n[]={0,0,0,0,0};
for(i=1;i<=4;i++)
{ n[i]=n[i-1]*2+1;
printf("%d ",n[i]);
}
}
思路分析
我第一眼看到這題的時候,我感覺好像要麼超級難,要麼超級簡單,我第一反應是,會不會是0,因爲n數組中的元素都是0,看了看 for循環,應該不會是0,因爲後面一直+1,然後我就假設性原則,硬算了
當i=1時,n[1]=n[1-1]*2+1 = 1 (n[1-1]即爲n[0]=0)
當i=2時,n[2]=n[2-1]*2+1 = 3 (根據上面的推斷, n[1]=1, 1*2+1=3)
當i=3時,n[3]=n[3-1]*2+1 = 7 (n[2]=3,3*2+1=7)
當i=4時,n[4]=n[4-1]*2+1 = 15 (n[3]=7 7*2+1 =15)
i=5不滿足for循環條件
所以打印出的結果應該是1,3,7,15
擼寫代碼
#include<stdio.h>
int main()
{
int i,n[]={0,0,0,0,0};
for(i=1;i<=4;i++)
{
n[i]=n[i-1]*2+1;
printf("%d ",n[i]);
}
return 0;
}
驗證結果
和分析的結果一樣,可以可以!