算法训练营 训练 间谍(C语言)

本文介绍了一个用于筛选间谍名单的简单算法。该算法通过对比三份名单,找出由敌对方派出的间谍,并确保双重间谍能够顺利返回。通过字符串处理实现目标名单的筛选。

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

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);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

羽星_s

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值