编程题目,求大神纳
、分别将a、b所指字符串中字符倒序,然后按排列的顺序交叉合并到c所指数组中,过长的剩余字符接在c所指数组的尾部。例如,当a所指字符串中的内容为:"abcdefg",b所指...
、 分别将a、b所指字符串中字符倒序,然后按排列的顺序交叉合并到c所指数组中,过长的剩余字符接在c所指数组的尾部。例如,当a所指字符串中的内容为:"abcdefg",b所指字符串中的内容为:"1234"时,则c所指数组中的内容应该为:"g4f3e2d1cba";而当a所指字符串中的内容为:"1234",b所指字符串中的内容为:"abcdefg"时,则c所指数组中的内容应该为:"4g3f2e1dcba"。
展开
1个回答
展开全部
这个程序就是你要的答案,我已经用你的数据在vc6下通过测试运行了
#include<stdio.h>
#include<string.h>
void main()
{
char a[50]="",b[50]="",c[100]="",ch='\0';
int i=0,j=0,k=0;
printf("input string a:");
gets(a);
printf("input string b:");
gets(b);
for(;i<=(strlen(a)-1)/2;i++)
{
ch=*(a+i);
*(a+i)=*(a+strlen(a)-1-i);
*(a+strlen(a)-1-i)=ch;
}
for(;j<=(strlen(b)-1)/2;j++)
{
ch=*(b+j);
*(b+j)=*(b+strlen(b)-1-j);
*(b+strlen(b)-1-j)=ch;
}
for(j=0,k=0,i=0;(*(a+i)!='\0')&&(*(b+j)!='\0');)
{
*(c+k++)=*(a+i++);
*(c+k++)=*(b+j++);
}
if(strlen(a)>strlen(b))
for(;*(a+i)!='\0';)
*(c+k++)=*(a+i++);
else
for(;*(b+j)!='\0';)
*(c+k++)=*(b+j++);
*(c+k)='\0';
printf("result is:");
puts(c);
}
#include<stdio.h>
#include<string.h>
void main()
{
char a[50]="",b[50]="",c[100]="",ch='\0';
int i=0,j=0,k=0;
printf("input string a:");
gets(a);
printf("input string b:");
gets(b);
for(;i<=(strlen(a)-1)/2;i++)
{
ch=*(a+i);
*(a+i)=*(a+strlen(a)-1-i);
*(a+strlen(a)-1-i)=ch;
}
for(;j<=(strlen(b)-1)/2;j++)
{
ch=*(b+j);
*(b+j)=*(b+strlen(b)-1-j);
*(b+strlen(b)-1-j)=ch;
}
for(j=0,k=0,i=0;(*(a+i)!='\0')&&(*(b+j)!='\0');)
{
*(c+k++)=*(a+i++);
*(c+k++)=*(b+j++);
}
if(strlen(a)>strlen(b))
for(;*(a+i)!='\0';)
*(c+k++)=*(a+i++);
else
for(;*(b+j)!='\0';)
*(c+k++)=*(b+j++);
*(c+k)='\0';
printf("result is:");
puts(c);
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询