本题要求实现一个函数,将第二个字符串中与第一个字符串的不同字符连接到字符串1后面。
函数接口定义:
void strDifcat(char *dst,char *src);
dst、src分别指向主调函数中的第一个字符串和第二个字符串,最终连接完成的字符串由dst指向。
裁判测试程序样例:
在这里给出函数被调用进行测试的例子。例如:
#include <stdio.h>
#include <string.h>
#define NLEN 10
void strDifcat(char *dst,char *src);
int main(void)
{
char srcStr1[2*NLEN],srcStr2[NLEN];
gets(srcStr1);
gets(srcStr2);
strDifcat(srcStr1,srcStr2);
puts(srcStr1);
return 0;
}
/* 请在这里填写答案 */
输入样例1:
student
jack
输出样例1:
studentjack
输入样例2:
student
john
输出样例2:
studentjoh
答案代码:
void strDifcat(char *dst,char *src)
{
char temp[80];
int dl,sl,flag; //dl sl分别表示两字符串的长度
dl=strlen (dst); //计算长度
sl=strlen (src);
int i,j,k=0;
for (i=0;i<sl;i++)//对src中的每个字符进行检测,,检测是否与dst中的字符重复
{
flag=1; //默认为不重复
for (j=0;j<dl;j++)
{
if (src[i]==dst[j]) flag=0;//与dst中的每一个字符进行比对
} //但凡有一个重复则flag为0
if (flag==1) //一个重复都没有
{
temp[k]=src[i]; //放到temp这个字符串中
k++;
}
}
temp[k]='\0'; //结尾这个很重要
strcat(dst,temp); //这个函数可以把一个字符串连接到另一个字符串尾部
}