合并两个字符集合为一个新集合,每个字符串在新集合中仅出现一次,函数返回新集合中字符串。
2016-10-31 22:36
387 查看
/*****************************************************
copyright (C), 2014-2015, Lighting Studio. Co., Ltd.
File name:
Author:Jerey_Jobs Version:0.1 Date:
Description:
Funcion List:
*****************************************************/
//合并两个字符集合为一个新集合,每个字符串在新集合中仅出现一次,函数返回新集合中字符串。
// 如:
// 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<string.h>
void str_cat(char a[][10], char b[][10], char c[][10], int n, int m)
{
int i;
int j;
int k=n;
int count;//比较b中字符串和a中字符串相同的个数计数
for (i = 0; i < n; i++)//字符数组a中无相同项直接拷贝到c
{
strcpy(c[i],a[i]);
}
for (i = 0; i < m; i++)
{
for (j = 0; j < n; j++)
{
if ((strcmp(b[i],a[j])) == 0)
{
count++;
}
}
if (count == 0)//无相同项,将字符串拷贝到c
{
strcpy(c[k],b[i]);
k++;
}
count = 0;//重新赋值用于计数
}
printf("Puts string c!\n");
for (i = 0; i < k; i++)
{
printf("%s ",c[i]);
}
printf("\n");
}
int main()
{
int i;
int j;
int numa;
int numb;
char a[10][10];
char b[10][10];
char c[20][10];
printf("Enter number of a!(<=10))!\n");//输入字符数组a的长度
scanf("%d",&numa);
printf("Enter string a!\n");
for (i = 0; i < numa; i++)//输入字符数组a
{
scanf("%s",a[i]);
}
printf("Enter number of b!(<=10))!\n");//输入字符数组b的长度
scanf("%d",&numb);
printf("Enter string b!\n");
for( j = 0; j < numb; j++)//输入字符数组b
{
scanf("%s",b[j]);
}
str_cat(a,b,c,numa,numb);
return 0;
}
copyright (C), 2014-2015, Lighting Studio. Co., Ltd.
File name:
Author:Jerey_Jobs Version:0.1 Date:
Description:
Funcion List:
*****************************************************/
//合并两个字符集合为一个新集合,每个字符串在新集合中仅出现一次,函数返回新集合中字符串。
// 如:
// 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<string.h>
void str_cat(char a[][10], char b[][10], char c[][10], int n, int m)
{
int i;
int j;
int k=n;
int count;//比较b中字符串和a中字符串相同的个数计数
for (i = 0; i < n; i++)//字符数组a中无相同项直接拷贝到c
{
strcpy(c[i],a[i]);
}
for (i = 0; i < m; i++)
{
for (j = 0; j < n; j++)
{
if ((strcmp(b[i],a[j])) == 0)
{
count++;
}
}
if (count == 0)//无相同项,将字符串拷贝到c
{
strcpy(c[k],b[i]);
k++;
}
count = 0;//重新赋值用于计数
}
printf("Puts string c!\n");
for (i = 0; i < k; i++)
{
printf("%s ",c[i]);
}
printf("\n");
}
int main()
{
int i;
int j;
int numa;
int numb;
char a[10][10];
char b[10][10];
char c[20][10];
printf("Enter number of a!(<=10))!\n");//输入字符数组a的长度
scanf("%d",&numa);
printf("Enter string a!\n");
for (i = 0; i < numa; i++)//输入字符数组a
{
scanf("%s",a[i]);
}
printf("Enter number of b!(<=10))!\n");//输入字符数组b的长度
scanf("%d",&numb);
printf("Enter string b!\n");
for( j = 0; j < numb; j++)//输入字符数组b
{
scanf("%s",b[j]);
}
str_cat(a,b,c,numa,numb);
return 0;
}
相关文章推荐
- 合并两个字符集合为一个新集合,每个字符串在新集合中仅出现一次,函数返回新集合中字符串。
- 合并两个字符集合为一个新集合,每个字符串在新集合中仅出现一次,函数返回新集合中字符串。 如: s1集合{“while”,”for”,”switch”,”if”,”continue”
- 请实现一个函数用来找出字符流中第一个只出现一次的字符。例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g"。当从该字符流中读出前六个字符“google"时,第一个只出现一次的字符是"l"。
- 统计字符串中每个字符的出现频率,返回一个 Object,key 为统计字符,value 为出现频率
- 有n个长为m+1的字符串, 如果某个字符串的最后m个字符与某个字符串的前m个字符匹配,则两个字符串可以联接, 问这n个字符串最多可以连成一个多长的字符串,如果出现循环,则返回错误。
- 有n 个长为m+1 的字符串,如果某个字符串的最后m 个字符与某个字符串的前m 个字符匹配,则两个字符串可以联接,问这n 个字符串最多可以连成一个多长的字符串,如果出现循环,则返回错误
- 在一个字符串(1<=字符串长度<=10000,全部由大写字母组成)中找到第一个只出现一次的字符,并返回它的位置
- 请实现一个函数用来找出字符流中第一个只出现一次的字符。例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g"。当从该字符流中读出前六个字符“google"时,第一个只出现一次的字
- 在一个字符串(1<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置
- 在一个字符串(1<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置
- 给定两个字符串和一个字典,从头到尾找到最短变换序列的长度,使得:一次只能改变一个字符每个中间词必须存在于字典中
- 手把手地写了一个函数,计算出两个字符串日期之间的所有字符串型日期 集合
- 在一个字符串(1<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置
- 26.在一个字符串(1<=字符串长度<=10000,全部由大写字母组成)中找到第一个只出现一次的字符,并返回它的位置
- 请实现一个函数用来找出字符流中第一个只出现一次的字符。例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g"。
- 有n个长为m+1的字符串,如果某个字符串的最后m个字符与某个字符串的前m个字符匹配,则两个字符串可以联接,问这n个字符串最多可以连成一个多长的字符串,如果出现循环,则返回错误。
- 在一个字符串(1<=字符串长度<=10000,全部由大小写字母组成)中找到第一个只出现一次的字符,并返回它的位置
- PHP 有n 个长为m+1 的字符串, 如果某个字符串的最后m 个字符与某个字符串的前m 个字符匹配,则两个字符串可以联接, 问这n 个字符串最多可以连成一个多长的字符串,如果出现循环,则返回错误
- [剑指Offer-字符串]请实现一个函数用来找出字符流中第一个只出现一次的字符。
- 26.在一个字符串(1<=字符串长度<=10000,全部由大写字母组成)中找到第一个只出现一次的字符,并返回它的位置