結果
| 問題 | No.327 アルファベット列 |
| コンテスト | |
| ユーザー |
u-ske1
|
| 提出日時 | 2020-06-26 13:58:02 |
| 言語 | C#(csc) (csc 3.9.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,255 bytes |
| コンパイル時間 | 3,171 ms |
| コンパイル使用メモリ | 110,128 KB |
| 実行使用メモリ | 28,228 KB |
| 最終ジャッジ日時 | 2024-07-03 22:43:38 |
| 合計ジャッジ時間 | 3,245 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 3 WA * 47 |
コンパイルメッセージ
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(ans);
}
}
u-ske1