作业帮 > 综合 > 作业

C语言:有n个整数,使前面各数顺序向后移m个位置,最后m个数变成前面m个数.写一函数实现

来源:学生作业帮 编辑:作业帮 分类:综合作业 时间:2024/05/14 18:14:17
C语言:有n个整数,使前面各数顺序向后移m个位置,最后m个数变成前面m个数.写一函数实现
我写了程序 语法没有错误 但是没有办法把最后m个数变成前面m个数.以后长期定向提问
#include
int *p,n,m,a[100];
void swap(int *p,int n,int m)
{
int i,j,*t,b[100];
\x05t=b;
\x05for(j=n-1;j>=m;j--)
\x05{
\x05 *(t+j)=*(p+j);
\x05 }
for(i=m-1;i>=0;i--)
\x05 {
\x05\x05*(p+i+m)=*(p+i);
}
\x05for(j=n-1;j>=m;j--)
\x05{
\x05 *(p+j+m)=*(t+j);
\x05}
}\x05
int main()
{
\x05int i;
\x05printf("输入数据的个数以及想要从哪里开始移动:\n");
scanf("%d%d",&n,&m);
printf("输入移动前的数组为:\n");
for(i=0;i
void swap(int *p,int n,int m)
{
\x05int i,j,*t,b[100];
\x05t=b;
\x05for(i=0;i=m;i--)
\x05{
\x05\x05p[i] = p[i-m];
\x05}
\x05for(i=0;i
再问: 这样的话 * t不就可以不用了?
再答: 嗯,忘记删了
再问: 那我想问一下 为什么我用指针t的话程序就是错的呢?
再答: 不是指针就错,而是你的算法有问题 你的代码等价于 void swap(int *p, int n, int m) { int i,j,*t,b[100]; t=b; for(j=n-1;j>=m;j--) { b[j]=p[j]; // 把m到n-1复制到b } for(i=m-1;i>=0;i--) { p[i+m]=p[i]; // 把前面m个往后面挪 } for(j=n-1;j>=m;j--) { p[j+m]=b[j]; // 这行在j=n-1的时候,p[j+m]已经越界了 } }