【链表】 HRBUST 2027 Party

Party

Time Limit: 500 MS Memory Limit: 32768 K

Description

传言说,假期结束后,会有一个奖励party,请每次做题最多的同学去吃饭。这个时候难免就要统计一下人数喽。可是人太多了,不好统计。你能帮忙吗?

Input

只有一组数据(数据量巨大呦)
由两部分,第一部分:
每行一个人的名字,只有小写字母组成。
以END结束
第二部分,若干个询问:
每行一个名字,只有小写字母组成。
以END结束。

所有字符串长度小于100。

Output

对于每个询问,如果在第一部分的名单中出现了,输出“Yes”
没有出现,输出“No”
(不包含引号)

Sample Input

zhangsan
lisi
wangwu
END
liliu
lisi
END

Sample Output

No
Yes

Source

2014 Winter Holiday Contest 4

题意

给你很多个字符串,然后给你一些需要查找的字符串,让你查找在先前的字符串当中是否有带查找的字符串。

思路

我用链表写了一波,感觉指针操作很舒服,虽然代码写的很丑【跑

AC代码

#include<bits/stdc++.h>
using namespace std;

struct Every{
    char a[106];
    Every *next;//指向下一个结构体的指针。
};

typedef struct Every poi; //自定义名称。

void solve(void)
{
    poi first;
    poi *p = &first;//伪—头指针。
    char temp[106];
    while(scanf("%s",temp),strcmp(temp,"END")!=0){
        poi *n = new poi;//申请一个poi大小的内存空间。
        strcpy(p->a,temp);//将当前的字符串拷贝到这个空间当中。
        p->next = n;//上一个结构体当中储存下一个结构体地址的空间储存当前新分配的结构体的地址。
        p = n;//指针后移,使指针指向当前的结构体,成为‘上一个’结构体。
    }
    p->next = NULL;//最后的结构体的指针指向空,作为链表结束的标志。

    while(scanf("%s",temp),strcmp(temp,"END")!=0){
        p = &first;
        p = p->next;
        while(p->next!=NULL){//没有找到末尾
            if(strcmp(temp,p->a)==0){//如果找到就不用往下找了
                printf("Yes\n");
                break;
            }
            p = p->next;//指针后移,指向下一个结构体。
        }
        if(p==NULL) printf("No\n");//没找到的说最后指针必然指向NULL。
    }

}

int main(void)
{
    solve();
    return 0;
}

这题也可以用map来写而且思路贼简单【哇的一声

#include<bits/stdc++.h>
using namespace std;

void solve(void)
{
    string a;
    map<string,int>p;
    while(1)
    {
        cin>>a;
        if(a=="END") break;
        p[a] = 1;
    }
    while(1)
    {
        cin>>a;
        if(a=="END") break;
        if(p[a]==1){
            cout<<"Yes"<<endl;
        }
        else cout<<"No"<<endl;
    }

}

int main(void)
{
    solve();
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

两米长弦

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

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

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

打赏作者

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

抵扣说明:

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

余额充值