結果
| 問題 | No.701 ひとりしりとり | 
| コンテスト | |
| ユーザー |  | 
| 提出日時 | 2019-01-17 16:18:19 | 
| 言語 | Nim (2.2.0) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 10 ms / 2,000 ms | 
| コード長 | 854 bytes | 
| コンパイル時間 | 3,200 ms | 
| コンパイル使用メモリ | 64,932 KB | 
| 実行使用メモリ | 6,944 KB | 
| 最終ジャッジ日時 | 2024-07-01 10:05:59 | 
| 合計ジャッジ時間 | 3,821 ms | 
| ジャッジサーバーID (参考情報) | judge4 / judge5 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 12 | 
ソースコード
import strutils
proc putchar_unlocked(c:char){.header: "<stdio.h>" .}
const bound = 'z'.ord - 'a'.ord# [0,bound] まで使える
proc getAsciis(a:int): string =
  if a == 0: return "a"
  result = ""
  var n = a
  while n > 0:
    var c = chr('a'.ord + (n mod bound))
    if c == 'n' : c = 'z'
    result &= c
    n = n div bound
let n = stdin.readLine().parseInt()
for i in 0..<n div 2:
  let S = i.getAsciis()
  putchar_unlocked('a')
  for s in S: putchar_unlocked(s)
  putchar_unlocked('b')
  putchar_unlocked('\n')
  putchar_unlocked('b')
  for s in S: putchar_unlocked(s)
  if n mod 2 == 0 and i == n div 2 - 1:
    putchar_unlocked('n')
  else:putchar_unlocked('a')
  putchar_unlocked('\n')
if n mod 2 == 1:
  let S = (n div 2).getAsciis()
  putchar_unlocked('a')
  for s in S: putchar_unlocked(s)
  putchar_unlocked('n')
  putchar_unlocked('\n')
            
            
            
        