C语言 数组循环右移

谁来解释一下... 谁来解释一下 展开
 我来答
司马刀剑
高粉答主

2019-02-16 · 每个回答都超有意思的
知道顶级答主
回答量:4.6万
采纳率:93%
帮助的人:7446万
展开全部

#include<stdio.h>

#define N 1000

void reverser(int *a,int n,int m)

{

int i,k=0,t;

k=n%m;

for(i=0;i<=(m-1)/2;i++)//将数字换为原来整数的形式

{

t=a[m-1-i];

a[m-1-i]=a[i];

a[i]=t;

}

while(k>0)//移位

{

t=a[m-1];//将最后一个数字暂存!

for(i=m-2;i>=0;i--)//循环向右移位

a[i+1]=a[i];

a[0]=t;//将最后一个数字付给第一个数字

k--;

}

}

int main()

{

int a[N]={0},m=0,k,n,i;

printf("输入你要移位的数:");

scanf("%d",&k);

printf("输入移位多少位:");

scanf("%d",&n);

do{

a[m]=k%10;

k/=10;

m++;

}while(k>0);

reverser(a,n,m);

for(i=0;i<m;i++)

printf("%d",a[i]);

printf("\n");

return 0;

}

我这个里取了一个巧!直接输出了!

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式