C语言 | 对n个字符开辟连续的存储空间

例76:有n个整数,使前面各数顺序向后移动m个位置,最后m个数变成最前面m个数,C语言写一函数实现以上功能,在主函数中输入n个整数和输出调整后的n个数,要求用指针。

解题思路:读者看着道题的时候,首先要明白题意,要用函数和指针来做,读者如果嫌麻烦的话可以先不用指针,函数也可以先不抽取出来,就在主函数中写,然后按照题意修改下自己的代码。

C语言源代码演示:

#include<stdio.h>//头文件 
int main()//主函数 
{
  void move(int [20],int n,int m); //函数声明 
  int number[20],n,m,i;//定义整型变量和整型数组 
  printf("共有多少个数:");//提示语句 
  scanf("%d",&n);//键盘输入 
  printf("输入这%d个数\n",n);//提示语句 
  for(i=0;i<n;i++)
  { scanf("%d",&number[i]); //键盘录入n个数 
  }
  printf("向后移动多少个数:");//提示语句 
  scanf("%d",&m);//键盘输入 
  move(number,n,m); //move函数调用 
  for(i=0;i<n;i++)//输出结果 
  { printf("%d ",number[i]);
  }
  printf("\n");//换行 
  return 0;//主函数返回值为0 
}
void move(int array[20],int n,int m)//move函数功能的实现 
{ 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时,停止调用 
  }
}

编译运行结果如下:

共有多少个数:8
输入这8个数
12 43 65 67 8 2 1 11
向后移动多少个数:4
8 2 1 11 12 43 65 67

--------------------------------
Process exited after 17.88 seconds with return value 0
请按任意键继续. . .

以上,如果你看了觉得对你有所帮助,就给小林点个赞,分享给身边的人叭,这样小林也有更新下去的动力,跪谢各位父老乡亲啦~

C语言学习路线 mp.weixin.qq.com图标 推荐收藏 | 开发工具 mp.weixin.qq.com图标

文章来源: zhuanlan.zhihu.com,作者:小林C语言,版权归原作者所有,如需转载,请联系作者。

原文链接:zhuanlan.zhihu.com/p/349176108

(完)