zoukankan      html  css  js  c++  java
  • PAT 1069 微博转发抽奖

    https://pintia.cn/problem-sets/994805260223102976/problems/994805265159798784

    小明 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
    

    输出样例 2:

    Keep going...

    代码:
    #include <bits/stdc++.h>
    using namespace std;
    
    const int maxn = 1e5 + 10;
    char name[maxn][30];
    int m, n, s;
    map<string, int> mp;
    
    int main() {
      scanf("%d%d%d", &m, &n, &s);
      for(int i = 1; i <= m; i ++) {
        scanf("%s", name[i]);
      }
      int flag = 0;
    
      for(int i = s; i <= m; i = i + n) {
        while(mp[name[i]]) i ++;
        if(i > m) break;
        mp[name[i]] = 1;
        printf("%s
    ", name[i]);
        flag = 1;
      }
    
      if(flag == 0) {
        printf("Keep going...
    ");
      }
      return 0;
    }
    

      

  • 相关阅读:
    9-29 函数嵌套及作用域链
    9-29 函数进阶_命名空间和作用域
    9-28 函数
    9-27 文件的”改”、删、重命名
    9-26 联合文件的登录注册
    9-26 文件操作一些功能详解
    9-26 文件操作
    9-26 复习数据类型
    9-25 集合
    python基础day7_购物车实例
  • 原文地址:https://www.cnblogs.com/zlrrrr/p/9364087.html
Copyright © 2011-2022 走看看