合并两个字符集合为一个新集合,每个字符串在新集合中仅出现一次,函数返回新集合中字符串

该博客介绍了一个C语言实现的函数,用于合并两个包含字符串的数组,并确保新集合中每个字符串只出现一次。通过比较字符串并使用自定义的字符串比较函数mystrcmp,将不重复的字符串存储到新数组outbuf中。最后,展示了如何打印原始和合并后的字符串数组。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

合并两个字符集合为一个新集合,每个字符串在新集合中仅出现一次,函数返回新集合中字符串。
    如: s1集合{“while”,”for”,”switch”,”if”,”continue”}
            s2集合{“for”,”case”,”do”,”else”,”char”,”switch”}
    运行结果:

         while   for   switch   if  break   continue   case  do  else  char


#include <stdio.h>
#include <stdlib.h>


 //比较两个字符串的大小,大于则返回正数,小于负数,等于返回0
int mystrcmp(const char *str1, const char *str2)  
{
while (*str1 == *str2)
{
if (*str1 == '\0')
{
return 0;
}
str1++;
str2++;
}
return (*str1 - *str2);
}

//合并两个字符串,去除重复的字符串
int ConbineStr(char **str1, char **str2, char **outbuf) 
{
int i = 0;
int j = 0;
int k = 0;
int flag = 0;
char *t = NULL;
char *p = t;

t = (char *)malloc(10 * sizeof(char *));

for (i = 0; i < 5; i++)
{
outbuf[k++] = str1[i]; //先将str1中的字符串放入新的字符串中
}

for (i = 0; i < 6; i++)
{
flag = 0;
p = str2[i];
for (j = 0; j < 5; j++)
{
if (mystrcmp(p, str1[j]) == 0) //遍历第二个字符串数组,与第一个相比较,相同的就做标志1
{
flag = 1;
}
}
if (flag == 0)
{
outbuf[k++] = str2[i]; //去除相同的字符串,放入新的字符串中
}
}
free(t);

return k;   //返回字符串的个数
}

void PrintStr(char **str, int n)  //打印字符串数组
{
int i = 0;

for (i = 0; i < n; i++)
{
printf ("%s ", str[i]);
}
printf ("\n");
}

int main()
{
char *str1[] = {"while", "for", "switch", "if", "continue"};
char *str2[] = {"for", "case", "do", "else", "char", "switch"};
char *outbuf[100] = {0}; //用于存放新的字符串数组
int count = 0;

count = ConbineStr(str1, str2, outbuf);

printf ("The original strings are :\n");
PrintStr(str1, 5);
PrintStr(str2, 6);

printf ("\nThe result is :\n");
PrintStr(outbuf, count);

return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值