• PAT 1069 微博转发抽奖(20)(代码+思路+测试点4)


    1069 微博转发抽奖(20 分)

    小明 PAT 考了满分,高兴之余决定发起微博转发抽奖活动,从转发的网友中按顺序每隔 N 个人就发出一个红包。请你编写程序帮助他确定中奖名单。

    输入格式:

    输入第一行给出三个正整数 M(≤ 1000)、N 和 S,分别是转发的总量、小明决定的中奖间隔、以及第一位中奖者的序号(编号从 1 开始)。随后 M 行,顺序给出转发微博的网友的昵称(不超过 20 个字符、不包含空格回车的非空字符串)。

    输出格式:

    按照输入的顺序输出中奖名单,每个昵称占一行。如果没有人中奖,则输出 Keep going...

    输入样例 1:

    9 3 2
    Imgonnawin!
    PickMe
    PickMeMeMeee
    LookHere
    Imgonnawin!
    TryAgainAgain
    TryAgainAgain
    Imgonnawin!
    TryAgainAgain
    

    输出样例 1:

    PickMe
    Imgonnawin!
    TryAgainAgain
    

    输入样例 2:

    2 3 5
    Imgonnawin!
    PickMe

    测试点4输入:

    11 3 2
    Imgonnawin!
    PickMe
    PickMeMeMeee
    LookHere
    Imgonnawin!
    TryAgainAgain
    TryAgainAgain
    PickMe
    Imgonnawin!
    PickMe
    TryAgainAgain

    测试点4输出:

    PickMe
    Imgonnawin!
    TryAgainAgain

     PS:

          我的思路:相邻去重:每次与之前的字符串比较(第一次直接输入),根据题目条件输出"keep going",用map<string,int>记录该昵称的获奖情况。根据记录数据输出

          注意:1、去重只需要相邻昵称去重就行。

                     2、(测试点4)一个人只能获奖一次,可以在他获奖后直接在name中删除,这里我是通过map<string,int>存储获奖情况实现。

    #include<iostream>
    #include<string>
    #include<map>
    using namespace std;
    int main() {
    	map<string, int> map; //map用于判断改昵称是否已经获奖
    	int n, m, s;
    	int count = 0;
    	cin >> m >> n >> s;
    	string name[1001],str;
    	for (int i = 0; i < m; i++) {
    		cin >> str;
    		if (i == 0 || str != name[count -1 ])		//与前面进行的比较,去重
    			name[count++] = str;
    	}
    	if (m < s)
    		cout << "Keep going..." << endl;
    	else
    		for (int i = s - 1; i < m; i += n) {
    			while (map[name[i]] != 0)			//如果一个人已经获奖,就要“一直”往下找
    				i++;
    			cout << name[i] << endl;
    			map[name[i]]++;				
    		}
    	return 0;
    }
  • 相关阅读:
    VijosP1274:神秘的咒语
    2009年浙大 :找出直系亲属
    django用户信息扩展
    缓存
    自定义认证
    自定义admin
    权限的配置和使用
    form表单
    过滤器 自定义查询
    中间件
  • 原文地址:https://www.cnblogs.com/F-itachi/p/9974430.html
Copyright © 2020-2023  润新知