PAT乙1069 微博转发抽奖 a%n==s 和 (a-s)%n==0

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

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

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

输入样例 19 3 2
Imgonnawin!
PickMe
PickMeMeMeee
LookHere
Imgonnawin!
TryAgainAgain
TryAgainAgain
Imgonnawin!
TryAgainAgain
输出样例 1PickMe
Imgonnawin!
TryAgainAgain
输入样例 22 3 5
Imgonnawin!
PickMe
输出样例 2Keep going...
  • if(a%n==s) 若 n < s 则 a%n < s ——> 改为(a-s)%n==0,同时a要满足a>=s;
#include<iostream>
#include<cstdio>
#include<map>
using namespace std;
int m,n,s;
char t[25];
map<string,int>f;
int main()
{
    scanf("%d%d%d",&m,&n,&s);
    int a=0,flag=0;
    for(int i=0;i<m;i++)
    {
        scanf("%s",t);
        if(f[t])continue;
        a++;
    //  if(a%n==s)/////////
        if(a>=s&&(a-s)%n==0)
        {
            printf("%s\n",t);
            f[t]=1;
            flag=1;
        }
    }
    if(!flag)printf("Keep going...\n");
    return 0;
}

猜你喜欢

转载自blog.csdn.net/weixin_40367307/article/details/81295495