微博轉發抽獎,使用set解決

微博轉發抽獎

注題目非原創;
小明 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

#include <cstdio>
#include <set>
#include <string>
#include <iostream>
#include <algorithm>
using namespace std;

int m, n, s;
string arr[1005];
set<string> bi;



int main()
{
  cin >> m >> n >> s;
  for (int i = 1; i <= m; i++) cin >> arr[i];

  for(int i = s; i<=m; ) {
    if(bi.count(arr[i]) == 1) {
      i++;
      continue;
    }else{
      cout << arr[i] <<  endl;
      bi.insert(arr[i]);
      i+=n;
    }    
  }
  if (bi.size() == 0) cout << "Keep going..." << endl;
  return 0;
}
發佈了29 篇原創文章 · 獲贊 19 · 訪問量 2萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章