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

请编写函数实现如下功能:移动一维数组中的内容,若数组中有n个整数,要求把下标从0到p(p≤n-1)的数组元素平移到数组的最后。例如,一维数组中的原始内容为1,2,3,4,... 请编写函数实现如下功能:移动一维数组中的内容,若数组中有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:数组元素的个数*/
展开
 我来答
大_匆
2009-12-11 · TA获得超过201个赞
知道小有建树答主
回答量:91
采纳率:0%
帮助的人:0
展开全部
main()
{
void fun(int *w, int p, int n);
int a[20], n, i, p;
printf("输入元素的个数n:");
scanf("%d", &n);
printf("输入数组元素:");
for(i=0; i<n; i++)
scanf("%d", &a[i]);
printf("输入p的值:");
scanf("%d", &p);
fun(a, p, n);
for(i=0; i<n; i++)
printf("%d\t", *(a+i));
}
void fun(int *w, int p, int n)
{
int i, j, t;
for(i=p; i>=0; i--)
{
for(j=i; j<n-(p-i)-1; j++)
{
t=*(w+j); *(w+j)=*(w+j+1); *(w+j+1)=t;
}
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
handsomeIven
2009-12-10 · TA获得超过171个赞
知道小有建树答主
回答量:131
采纳率:0%
帮助的人:149万
展开全部
#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("Please input the p!\n");
scanf("%d",&p);
fun(a,p,N);
for(i=0;i<15;i++)
printf("%d\t",a[i]);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
佩棋教育
2009-12-10
知道答主
回答量:26
采纳率:0%
帮助的人:29.7万
展开全部
我可以把代码写给你。这个问题是这样的
在写代码之前我想问一下数组的大小是不是刚好装下这些整数,还是有空余位置??
比如你的问题有15个整数数据,是不是数组定义的大小就是w[15]??
你具体点告诉我给你写代码。

参考资料: 另外一楼的回答是我写的呵呵,呵呵忘记登陆了

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2009-12-10
展开全部
这个问题很简单,我可以回去编写代码给你。
在写代码之前我想问一下数组的大小是不是刚好装下这些整数,还是有空余位置??
比如你的问题有15个整数数据,是不是数组定义的大小就是w[15]??
你具体点告诉我给你写代码。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
jinguigame
2009-12-10 · 超过12用户采纳过TA的回答
知道答主
回答量:23
采纳率:0%
帮助的人:0
展开全部
#include <stdlib.h>

void fun( int* w, int p, int n )
{
int *pi, i;
pi = ( int* )malloc( (p+1) * sizeof(int) );
if (pi)
{
for( i = 0; i <= p; ++i )
*(pi+i) = w[i];
for( i = 0; i < (n-p-1); ++i )
w[i] = w[i+p+1];
for( i = 0; i <= p; ++i )
w[i+n-p-1] = *(pi+i);
free( pi );
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式