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单元位置,并输出显示。
展开
 我来答
李磊_1
2018-09-07 · TA获得超过299个赞
知道小有建树答主
回答量:337
采纳率:66%
帮助的人:120万
展开全部

参考如下代码:

#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;
}

结果:

White_MouseYBZ
2018-09-07 · TA获得超过4万个赞
知道大有可为答主
回答量:2.1万
采纳率:82%
帮助的人:6668万
展开全部
#include "stdio.h"
int main(int argc,char *argv[]){
int a[101],i;
for(a[100]=i=0;i<100;a[100]+=(a[i]=1+i++));
for(a[0]=a[100];i>1;a[i--]=a[i-1]);
for(a[1]=1,i=0;i<101;printf(i ? "%4d" : "%d:\n",a[i++]));
printf("\n");
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;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式