架构师_程序员_码农网

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 9583|回复: 0

[C] 指针方法 有N个整数,使前面的各数顺序向后移M个位置,最后M个数变成前面的M个数

[复制链接]
发表于 2015-12-15 16:40:22 | 显示全部楼层 |阅读模式
//有N个整数,使前面的各数顺序向后移M个位置,最后M个数变成前面的M个数,写一个函数实现以上功能,在主函数中输入N个整数N个整数和输出调整后的N个数。

#include "stdafx.h"
#include "stdio.h"
int main(int argc, char* argv[])
{void move(int array[20],int n,int m);
int number[20],n,m,i;
printf("how many numbers?");
scanf("%d",&n);
printf("input %d numbers:\n",n);
for(i=0;i<n;i++)
scanf("%d",&number[i]);
printf("how many place you want move?");
scanf("%d",&m);
move(number,n,m);
printf("now ,they are:\n");
for(i=0;i<n;i++)
printf("%d  ",number[i]);
printf("\n");
return 0;
}
void move(int array[20],int n,int m) //循环后移一次的函数
{int *p,array_end;
array_end=*(array+n-1);
for(p=array+n-1;p>array;p--)
    *p=*(p-1);
    *array=array_end;
    m--;
    if(m>0) move(array,n,m);       //递归调用,当循环次数M减到0时,停止调用
}






上一篇:学了好几天的指针,他到底是干啥用的,为什么会用到呢?
下一篇:c语言 分享国密算法 sms4 分组对称密码算法
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|手机版|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2024-4-24 10:43

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表