c语言编程题!高手作答!想要详细步骤~谢谢各位!!!

来源:百度知道 编辑:UC知道 时间:2024/06/15 18:48:49
请编写函数实现如下功能:移动一维数组中的内容,若数组中有n个整数,要求把下标从0到p(p≤n-1)的数组元素平移到数组的最后。例如,一维数组中的原始内容为1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,p的值为3。移动后,一维数组中的内容应为5,6,7,8,9,10,11,12,13,14,15,1,2,3,4。
函数原型为:void fun(int *w, int p, int n);
/*参数w:需要移动数据的数组*/
/*参数p:数组下标从0到p的元素平移到数组的最后*/
/*参数n:数组元素的个数*/

void fun(int *w,int p,int n)
{
int tmp,i,j;
for(i=0;i<=p;i++)
{
tmp = w[0];
for(j=1;j<n;j++)
{
w[j-1] = w[j];
}
w[n-1] = tmp;
}
}

这个问题很简单,我可以回去编写代码给你。
在写代码之前我想问一下数组的大小是不是刚好装下这些整数,还是有空余位置??
比如你的问题有15个整数数据,是不是数组定义的大小就是w[15]??
你具体点告诉我给你写代码。

我可以把代码写给你。这个问题是这样的
在写代码之前我想问一下数组的大小是不是刚好装下这些整数,还是有空余位置??
比如你的问题有15个整数数据,是不是数组定义的大小就是w[15]??
你具体点告诉我给你写代码。

#include<stdio.h>
#define N 15
void fun(int *w,int p,int n)
{ int a[10];//这儿的数组个数大于p即可
int i,j=0;
for(i=0;i<=p;i++)
a[i]=w[i];
for(i=p+1;i<=n;i++)
w[i-p-1]=w[i];
for(i=n-1-p;i<n;i++)
w[i]=a[j++];
}
void main()
{ int i,p,a[N];//这儿数组的个数可以自己决定
printf("Please input the array!\n");
for(i=0;i<15;i++)
scanf("%d",&a[i]);
printf("P