题目要求
以下程序运行后的输出结果是 。
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;
}
验证结果
和分析的结果一样,可以可以!