java实现有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数

 我来答
大野瘦子
高粉答主

2019-08-01 · 繁杂信息太多,你要学会辨别
知道小有建树答主
回答量:1227
采纳率:100%
帮助的人:34.7万
展开全部

错误一修改:

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

错误二修改:

void move(int a[],int n,int m)

{

int t[N];

int i,j=0;

for(i=n-m;i<n;i++) //把后面的取出放到t中

t[j++]=a[i]

for(i=0; i<n-m; i++) //前面的后移

a[i+m]=a[i];

for(i=0;i<m;i++) //把t中的放到前面

a[i]=t[i];

}

扩展资料:

注意事项

调用自定义后移函数move(int *a, int n, int m)来进行循环移位,对n(n<20)个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面m个数,如下: n=10, m=3时:输入:1 2 3 4 5 6 7 8 9 10,输出:8 9 10 1 2 3 4 5 6 7

Input

输入多组测试数据,每组先输入n(n < 20)和m(m < n),再输入n个整数。

Output

输出循环移动m个数后的序列,数据间空格隔开。

Sample Input

10 4

1 2 3 4 5 6 7 8 9 10

7 2

1 2 3 4 5 6 7

Sample Output

7 8 9 10 1 2 3 4 5 6

6 7 1 2 3 4 5

y1152979527
2012-12-19 · 超过14用户采纳过TA的回答
知道答主
回答量:60
采纳率:0%
帮助的人:33.8万
展开全部
x<<y 是用于二进制移位,表示数字 x*(2的y次方)。这里不能这么用
可以先将这n个整数的前n-m个数放入数组,然后将最后m个数再放入另一个数组。
俩数组交换位置合并就行了
追问
能给一下代码吗
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
白头乌翁
2012-12-19 · 超过15用户采纳过TA的回答
知道答主
回答量:143
采纳率:0%
帮助的人:61.7万
展开全部
使用数组啊
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
乐坊染天
2012-12-21 · TA获得超过976个赞
知道答主
回答量:27
采纳率:0%
帮助的人:15万
展开全部
public void chageNum(int m,int n)
int[] arr=new int[m];
int newarr=new int[m+n];
for(int i=0;i<=arr.length;i++)
{
newarr[i+n]=arr[i];
}
for(int j=0,j<n;j++){
newarr[j]=newarr[newarr.length-1-j];
}

}
来自:求助得到的回答
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
梦回弗里多
2012-12-19
知道答主
回答量:16
采纳率:0%
帮助的人:3.4万
展开全部
当然是用<<了。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 4条折叠回答
收起 更多回答(5)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式