zoukankan      html  css  js  c++  java
  • COGS 898. [咲 -Saki-] 天才麻将少女什么编

    ★☆   输入文件:sakinani.in   输出文件:sakinani.out   简单对比
    时间限制:1 s   内存限制:256 MB

    题目背景

    二十一世纪,世界上的麻将竞技人数超过一亿,日本每年也有大规模的全国大赛来对麻将选手进行选拔。从小学到高中,很多学校也设立了麻将部。

    《天才麻将少女阿知贺篇 episode of side-A》『 -Saki- 阿知賀編 episode of side-A』是《天才麻将少女》『 -Saki-』的外传,从另一个视角讲述麻将少女们的故事。故事背景设定在《天才麻将少女》本篇第二主角原村和曾生活的奈良县,主角校为阿知贺女子学院。(有问题?内事百度,外事谷歌)

    由于阿知贺人物存在感不够强,导致该作被称为“千里山篇”「 -Toki- 千里山編」,甚至 2012 年动画最萌也是千里山的園城寺怜同学。我们一直很疑惑这到底谁是主角,那么就让数据说话吧!

    题目要求

    我们给出一个人物列表,人物有其所属的学校。比如「松実玄」同学隶属「阿知賀女子学院」什么的。有的人物没有所属学校或没有明确给出其所属,可以无视。

    人物每一次出场都会给其学校增加一点存在感。有少数“被牌爱着的孩子”,即“魔物”会有非常高的存在感,出场一次会有普通人出场两次的存在感。

    我们需要统计,在给出的人物出场单中,哪个学校存在感最高,我们就把这篇动画命名为什么编。

    输入格式

    • 输入文件第一行为一个整数 n ,表示有多少人物出现。下面 n 行是人物列表,每两行有两个字符串 A 和 B ,表示人物 A 属于学校 B 。没有同名人物,不会重复出现人物。
    • 下面一行一个整数 k ,表示魔物的数量。接下来 k 行,每行一个字符串,表示魔物的姓名,不保证魔物在人物列表中。
    • 接下来直到文件末尾,每行有一个字符串(空行不算),表示出场人物,可能会出现不存在于上面列表中的人物。

    样例输入

    7
    宮永咲 清澄高校
    原村和 清澄高校
    片岡優希 清澄高校
    園城寺怜 千里山女子高校
    竹井久 清澄高校
    天江衣 龍門渕高校
    龍門渕透華 龍門渕高校
    2
    宮永咲
    天江衣
    
    原村和
    高鴨穏乃
    原村和
    片岡優希
    原村和
    宮永咲

    输出格式

    • 输出只有一行,即存在感最大的学校名称,并列第一则输出编码序小的一个。

    样例输出

    清澄高校

    数据范围及要求

    • 对于 70% 的数据,总出现次数不超过 10000。
    • 对于 100% 的数据,学校数量不超过 40 ,人物数量不超过 200 ,总出现次数不超过 1000000。
    • 对于 40% 的数据,字符串中只有大写和小写字母。
    • 对于 100% 的数据,字符串中会存在大小写字母、汉字和日语假名,且长度不超过 100 。为了简化问题,输入输出文件都使用 ANSI 编码(一个东亚字符占两字节)。

    模拟

    屠龙宝刀点击就送

    #include <algorithm>
    #include <iostream>
    #include <cstring>
    #include <cstdio>
    #include <string>
    #define N 1000005
    using namespace std;
    struct node
    {
        string name,sch;
        bool flag;
    }stu[N];
    struct nodE
    {
        string sch;
        int sum;
        bool operator<(nodE a)const
        {
            if(sum==a.sum) return sch<a.sch;
            else return sum>a.sum;
        }
    }sv[N];
    bool sq[N];
    int n,m,num;
    int Main()
    {
        freopen("sakinani.in","r",stdin);
        freopen("sakinani.out","w",stdout);
        scanf("%d",&n);
        string a,b;
        for(int i=1;i<=n;++i)
        {
            cin>>stu[i].name>>stu[i].sch;
            for(int j=1;j<=num;++j)
            {
                if(sv[j].sch==stu[i].sch)
                goto flag;
            }
            sv[++num].sch=stu[i].sch;
            flag:;
        }
        scanf("%d",&m);
        for(;m--;)
        {
            cin>>a;
            for(int i=1;i<=n;++i)
                if(stu[i].name==a) stu[i].flag=true;
        }
        while(cin>>a)
        {
            b.clear();
            int sum=0;
            for(int i=1;i<=n;++i)
                if(stu[i].name==a)
                {
                    b=stu[i].sch;
                    if(stu[i].flag) sum=2;
                    else sum=1;
                    break;
                }
            if(!b.size()) continue;
            for(int i=1;i<=num;++i)
            if(sv[i].sch==b) sv[i].sum+=sum;
        }
        sort(sv+1,sv+1+num);
        cout<<sv[1].sch;
        return 0;
    }
    int sb=Main();
    int main(int argc,char *argv[]) {;}
  • 相关阅读:
    POJ 1142 Smith Numbers
    POJ 1171 Letter Game 解题思路
    人人德克萨斯牌出手规则整理
    OpenMP相关知识索引
    如何进行有效的沟通
    台哥算法练习:一个for循环打印九九乘法表
    啊哈,381654729!
    发牌的小窍门
    判断数abcdef能否被k整除(k属于[2,9])
    如何在数轴上找到一个数的倒数
  • 原文地址:https://www.cnblogs.com/ruojisun/p/7694595.html
Copyright © 2011-2022 走看看