标签:get int 训练营 C语言 char ++ 间谍 SIZE
X国的情报委员收到一份可靠的信息,信息表明Y国将派间谍去窃取X国的机密文件。X国指挥官手中有两份名单列表,一份是Y国派往X国的间谍名单列表,另一份是X国以前派往Y国的间谍名单列表。这两份名单列表可能有些重叠。因为间谍可能同时扮演两个角色,称之为“双重间谍”。因此,Y国可以把双重间谍送回X国。很明显这对X国有利,因为双重间谍可以把Y国的机密文件带回,而不必担心被Y国边境拘留。所以指挥官决定抓住由Y国派出的间谍,让普通人和双重间谍进入。那么你能确定指挥官需要抓捕的间谍名单吗?
算法设计
定义3个字符串数组,记录3行名单。
判断第2行在第1行中出现但没在第3行中出现的字符串,将其打印出来
#include <stdio.h>
#include <string.h>
void * s_get(char m[], int n);/*字符串输入函数*/
#define SIZE 50
int main(void){
char x[SIZE], y[SIZE], z[SIZE],ans[SIZE], s[SIZE] = {'\0'};
int a, b, c, j = 0, bj = 0;
scanf("%d %d %d", &a, &b, &c);
s_get(x,a);
s_get(y,b);
s_get(z,c);
for (int i = 0; i < b; ++i) {
int l = 0;
for (; x[j] != ' ' && x[j] != '\0'; ++j) {
s[l++] = x[j];
}
j = j+1; /* 使索引跳过空格 */
s[l] = '\0';
if((strstr(x,s)) && (!strstr(z,s))){
printf("%s ",s);
bj = 1;
}
}
if(bj == 0){
printf("No enemy spy");
}
return 0;
}
void * s_get(char m[], int n){
char temp[10];
scanf("%s",m);
for (int i = 1; i < n; ++i) {
strcat(m," ");
scanf("%s",temp);
strcat(m,temp);
}
}
标签:get,int,训练营,C语言,char,++,间谍,SIZE 来源: https://blog.csdn.net/qq_20144897/article/details/122729669
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。