#UVa:11716-Digital Fortress

灆洢 2020-05-05 00:29:56

先確認輸入的字串長度是否為某整數的次方數,如果不是的話就是 INVALID;如果是的話就接著將該字串當成二維陣列去做巡覽即可得解。

C++(0.000)

/*******************************************************/
/* UVa 11716 Digital Fortress                          */
/* Author: Maplewing [at] knightzone.studio            */
/* Version: 2020/05/05                                 */
/*******************************************************/
#include <iostream>
#include <cstdio>
#include <cmath>
using namespace std;
const double DOUBLE_ERROR = 1e-9;
const int NOT_INTEGER_ROOT = -1;

bool isEqualWithError(double a, double b) {
  return a < b + DOUBLE_ERROR && a > b - DOUBLE_ERROR;
}

int findRoot(int number) {
  double realRoot = sqrt((double)number);
  int integerRoot = (int)realRoot;
  return isEqualWithError((double)integerRoot, realRoot) ? integerRoot : NOT_INTEGER_ROOT;
}

int main() {
  int T;
  while (scanf("%d ", &T) != EOF) {
    for (int caseNumber = 1 ; caseNumber <= T ; ++caseNumber) {
      string cipherText;
      getline(cin, cipherText);
      int cipherTextLength = cipherText.length();

      int rootNumber = findRoot(cipherTextLength);
      if (rootNumber == NOT_INTEGER_ROOT) {
        printf("INVALID\n");
        continue;
      }

      for (int i = 0 ; i < rootNumber ; ++i) {
        for (int j = 0 ; j < rootNumber ; ++j) {
          printf("%c", cipherText[i + j * rootNumber]);
        }
      }
      printf("\n");
    }
  }
}

發佈留言

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

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