結果
| 問題 | No.327 アルファベット列 |
| コンテスト | |
| ユーザー |
u-ske1
|
| 提出日時 | 2020-06-26 14:05:32 |
| 言語 | C#(csc) (csc 3.9.0) |
| 結果 |
AC
|
| 実行時間 | 26 ms / 2,000 ms |
| コード長 | 1,282 bytes |
| コンパイル時間 | 707 ms |
| コンパイル使用メモリ | 105,216 KB |
| 実行使用メモリ | 19,328 KB |
| 最終ジャッジ日時 | 2024-07-03 22:53:24 |
| 合計ジャッジ時間 | 3,165 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 50 |
コンパイルメッセージ
Microsoft (R) Visual C# Compiler version 3.9.0-6.21124.20 (db94f4cc) Copyright (C) Microsoft Corporation. All rights reserved.
ソースコード
using System;
using System.Collections.Generic;
using System.Linq;
public class Hello
{
public static void Main()
{
//アルファベットテーブルを作成する
var alpha = new string[26] { "A", "B", "C", "D", "E",
"F", "G", "H", "I", "J", "K",
"L", "M", "N", "O", "P", "Q",
"R", "S", "T", "U", "V", "W",
"X", "Y", "Z" };
var N = long.Parse(Console.ReadLine());
var e = 1L;
var cnt = 1;
//while (26 <= N)
//=> 最初このような書き方をしていたが、
//この書き方だとN=701のようなときNが負の値になってしまい、実行時エラーとなる。
while (e * 26 <= N)
{
N = N- (long)Math.Pow(26, cnt);
//26の階乗の数より小さいかチェックするための変数を設ける
e *=26;
cnt++;
}
var ans = "";
//最後尾の文字列から順に回答を組み立てていく
for(int num=cnt-1;0<=num;num--)
{
ans=ans +alpha[N%26];
N /= 26;
}
Console.WriteLine(String.Join("", ans.Reverse()));
}
}
u-ske1