結果
| 問題 | No.327 アルファベット列 |
| コンテスト | |
| ユーザー |
u-ske1
|
| 提出日時 | 2020-06-26 13:15:22 |
| 言語 | C#(csc) (csc 3.9.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,288 bytes |
| コンパイル時間 | 2,279 ms |
| コンパイル使用メモリ | 110,468 KB |
| 実行使用メモリ | 28,340 KB |
| 最終ジャッジ日時 | 2024-07-03 22:16:01 |
| 合計ジャッジ時間 | 3,130 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | WA * 3 |
| other | WA * 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++;
}
Console.WriteLine(cnt);
var ans = "";
//最後尾の文字列から順に回答を組み立てていく
for(int num=cnt-1;0<=num;num--)
{
ans=ans +alpha[N%26];
N /= 26;
}
Console.WriteLine(ans);
}
}
u-ske1