#UVa:10190-Divide, But Not Quite Conquer!

灆洢 2020-05-08 01:33:23

照題目將整個數列求出來即可。若是中途遇到不能整除,或是 n 或 m 剛開始就小於等於 1 的話,就輸出 Boring! 即可。

C++(0.000)

/*******************************************************/
/* UVa 10190 Divide, But Not Quite Conquer!            */
/* Author: Maplewing [at] knightzone.studio            */
/* Version: 2020/05/08                                 */
/*******************************************************/
#include <iostream>
#include <cstdio>
#include <vector>
#include <string>
using namespace std;

const string BORING_OUTPUT = "Boring!\n";

int main() {
  int n, m;
  while (scanf("%d%d", &n, &m) != EOF) {
    if (n <= 1 || m <= 1) {
      printf("%s", BORING_OUTPUT.c_str());
      continue;
    }

    vector<int> sequence;
    for (int i = n ; i == 1 || (i > 1 && i % m == 0) ; i /= m) {
      sequence.push_back(i);
    }

    int sequenceSize = sequence.size();
    if (sequenceSize == 0 || sequence[sequenceSize - 1] != 1) {
      printf("%s", BORING_OUTPUT.c_str());
      continue;
    }

    for (int i = 0 ; i < sequenceSize ; ++i) {
      if (i > 0) printf(" "); 
      printf("%d", sequence[i]);
    }
    printf("\n");
  }

  return 0;
}

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *

這個網站採用 Akismet 服務減少垃圾留言。進一步瞭解 Akismet 如何處理網站訪客的留言資料