C语言编程 一维数组元素移动
请定义一个大小为101个单元的整型一维数组,在0至99位置分别存放1至100的数值;然后从最后一个位置起,逐一将数据移到后一个单元(如将99单元的数值100,移到第100...
请定义一个大小为101个单元的整型一维数组,在0至99位置分别存放1至100的数值;
然后从最后一个位置起,逐一将数据移到后一个单元(如将99单元的数值100,移到第100单元,将98单元的数值99,移到第99单元,…,将0单元的数值1,移到第1单元);
最后将第1单元至第100单元的100个数值加起来,放在第0单元位置,并输出显示。 展开
然后从最后一个位置起,逐一将数据移到后一个单元(如将99单元的数值100,移到第100单元,将98单元的数值99,移到第99单元,…,将0单元的数值1,移到第1单元);
最后将第1单元至第100单元的100个数值加起来,放在第0单元位置,并输出显示。 展开
3个回答
展开全部
参考如下代码:
#include <stdio.h>
#define ARRAY_LENGTH 101
int main(int argc, char** argv)
{
// 初始化,将第 i 个元素的值为 i + 1
int values[ARRAY_LENGTH];
for (int i = 0; i < ARRAY_LENGTH; i++)
{
values[i] = i + 1;
}
// 最后一个元素为 0
values[ARRAY_LENGTH - 1] = 0;
// 元素值得和,这里用 long 的原因是,如果用 int
// 可能导致溢出(这里不会,和应该是 5050)
long sum = 0;
// 从后向前移动,这里因为上一步设置了最后一个元素为 0,
// 所以这里可以不用校验索引,如果没有设置最后一个元素为
// 0,应该忽略最后一个元素
for (int i = ARRAY_LENGTH - 1; i > 0; i--)
{
sum += i;
values[i] = values[i - 1];
}
// 最后设置第 0 个元素为总和
values[0] = sum;
for (int i = 0; i < ARRAY_LENGTH; i++)
{
printf_s("%d\n", values[i]);
}
return 0;
}
结果:
2018-09-07
展开全部
int main()
{
int s[101];
int i,sum=0;
for(i=0;i<100;i++)
{
s[i]=i+1;
sum+=s[i];
}
for(i=100;i>0;i--)
{
s[i]=s[i-1];
}
s[0]=sum;
for(i=0;i<101;i++)
{
printf("%d ",s[i]);
}
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询