C程序改正:编写函数实现将数组后n个元素移到数组的前面,成为前n个元素,求改正
要求main函数中输入n,并将n作为参数呢,最后在main函数中输出#include<stdio.h>#include<string.h>voidmain(){charF...
要求main函数中输入n,并将n作为参数呢,最后在main函数中输出
#include<stdio.h>
#include<string.h>
void main()
{
char Fun(int x);
int n;
char a[100],b[100],c[100];
puts("please press shuzu");
gets(a);
printf("please press n");
scanf("%d",&n);
Fun(n);
puts(c);
puts('\0');
}
char Fun(int x)
{
int i,j=0,k=0,l,n;
char a[100],b[100],c[100];
l=strlen(a);
for(i=0;i<l-n;i++)
b[j++]=a[i];
for(i=l-n;i<n;i++)
c[k++]=a[i];
strcat(c,b);
return(x);
} 展开
#include<stdio.h>
#include<string.h>
void main()
{
char Fun(int x);
int n;
char a[100],b[100],c[100];
puts("please press shuzu");
gets(a);
printf("please press n");
scanf("%d",&n);
Fun(n);
puts(c);
puts('\0');
}
char Fun(int x)
{
int i,j=0,k=0,l,n;
char a[100],b[100],c[100];
l=strlen(a);
for(i=0;i<l-n;i++)
b[j++]=a[i];
for(i=l-n;i<n;i++)
c[k++]=a[i];
strcat(c,b);
return(x);
} 展开
2个回答
展开全部
给你改好了。
加工后要带回的a[] 要设为参数 或 全局量才行。
#include<stdio.h>
main()
{
void Fun(char *a, int n);
int n;
char a[100];
puts("please input char shuzu");
gets(a);
printf("please input n\n");
scanf("%d",&n);
Fun(a,n);
puts(a);
puts("\0");
return 0;
}
void Fun(char *a, int n)
{
int i,j=0,k=0,l;
char b[100],c[100];
l=strlen(a);
for(i=0;i<l-n;i++){
b[j++]=a[i];
}
b[j]='\0';
for(i=l-n;i<l;i++)c[k++]=a[i];
c[k]='\0';
strcpy(a,c);
strcat(a,b);
}
加工后要带回的a[] 要设为参数 或 全局量才行。
#include<stdio.h>
main()
{
void Fun(char *a, int n);
int n;
char a[100];
puts("please input char shuzu");
gets(a);
printf("please input n\n");
scanf("%d",&n);
Fun(a,n);
puts(a);
puts("\0");
return 0;
}
void Fun(char *a, int n)
{
int i,j=0,k=0,l;
char b[100],c[100];
l=strlen(a);
for(i=0;i<l-n;i++){
b[j++]=a[i];
}
b[j]='\0';
for(i=l-n;i<l;i++)c[k++]=a[i];
c[k]='\0';
strcpy(a,c);
strcat(a,b);
}
展开全部
#include <stdio.h>
void sort(char** p,int n,int s){
int i;
char *temp;
for (i = 0; i < n-s; i++) {
temp = *(p+i);
*(p+i) = *(p+s+i);
*(p+s+i) = temp;
}
}
int main(int argc, const char * argv[]) {
printf("用函数实现将给定数组的后m个元素移至最前面\n");
int i,j;
printf("输入N个元素构成数组(元素0-20位):");
scanf("%d",&j);
char **p,*pstr[j],str[j][20];
for(i=0;i<j;i++){
pstr[i]=str[i];
}
for(i=0;i<j;i++){
printf("输入第%d个字符串:",i+1);
scanf("%s",pstr[i]);
}
p=pstr;
int m;
printf("请输入第几个元素之后移至最前面:");
scanf("%d",&m);
sort(p,j,m);
for(i=0;i<j;i++){
printf("%s\n",pstr[i]);
}
return 0;
}
void sort(char** p,int n,int s){
int i;
char *temp;
for (i = 0; i < n-s; i++) {
temp = *(p+i);
*(p+i) = *(p+s+i);
*(p+s+i) = temp;
}
}
int main(int argc, const char * argv[]) {
printf("用函数实现将给定数组的后m个元素移至最前面\n");
int i,j;
printf("输入N个元素构成数组(元素0-20位):");
scanf("%d",&j);
char **p,*pstr[j],str[j][20];
for(i=0;i<j;i++){
pstr[i]=str[i];
}
for(i=0;i<j;i++){
printf("输入第%d个字符串:",i+1);
scanf("%s",pstr[i]);
}
p=pstr;
int m;
printf("请输入第几个元素之后移至最前面:");
scanf("%d",&m);
sort(p,j,m);
for(i=0;i<j;i++){
printf("%s\n",pstr[i]);
}
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询