結果
| 問題 | No.701 ひとりしりとり | 
| コンテスト | |
| ユーザー |  | 
| 提出日時 | 2019-01-17 16:37:15 | 
| 言語 | Nim (2.2.0) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 3 ms / 2,000 ms | 
| コード長 | 961 bytes | 
| コンパイル時間 | 2,353 ms | 
| コンパイル使用メモリ | 60,812 KB | 
| 実行使用メモリ | 6,944 KB | 
| 最終ジャッジ日時 | 2024-07-01 10:06:27 | 
| 合計ジャッジ時間 | 2,915 ms | 
| ジャッジサーバーID (参考情報) | judge3 / judge5 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 12 | 
ソースコード
proc putchar_unlocked(c:char){.header: "<stdio.h>" .}
proc scanf(formatstr: cstring){.header: "<stdio.h>", varargs.}
proc printAsciis(a:int) =
  const bound = 'z'.ord - 'a'.ord
  if a == 0:
    putchar_unlocked('a')
    return
  var n = a
  while n > 0:
    var c = chr('a'.ord + (n mod bound))
    if c == 'n' : c = 'z'
    putchar_unlocked(c)
    n = n div bound
var n : int
scanf("%d",addr n)
# a [b,c,...,z]
var dst = 0
var ascii = 0
for i in 0..<n div 2:
  var dstC = chr('a'.ord + dst + 1)
  if dstC == 'n' : dstC = 'z'
  putchar_unlocked('a')
  ascii.printAsciis()
  putchar_unlocked(dstC)
  putchar_unlocked('\n')
  putchar_unlocked(dstC)
  ascii.printAsciis()
  if n mod 2 == 0 and i == n div 2 - 1:
    putchar_unlocked('n')
  else:putchar_unlocked('a')
  putchar_unlocked('\n')
  dst += 1
  if dst == 24:
    ascii += 1
    dst = 0
if n mod 2 == 1:
  putchar_unlocked('a')
  (n div 2).printAsciis()
  putchar_unlocked('n')
  putchar_unlocked('\n')
            
            
            
        