結果

問題 No.238 Mr. K's Another Gift
ユーザー 👑 obakyanobakyan
提出日時 2020-04-23 23:16:00
言語 Lua
(LuaJit 2.1.1696795921)
結果
AC  
実行時間 4 ms / 2,000 ms
コード長 1,743 bytes
コンパイル時間 143 ms
コンパイル使用メモリ 6,688 KB
実行使用メモリ 5,376 KB
最終ジャッジ日時 2024-04-22 03:49:43
合計ジャッジ時間 1,814 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
5,248 KB
testcase_01 AC 2 ms
5,376 KB
testcase_02 AC 1 ms
5,376 KB
testcase_03 AC 2 ms
5,376 KB
testcase_04 AC 1 ms
5,376 KB
testcase_05 AC 4 ms
5,376 KB
testcase_06 AC 3 ms
5,376 KB
testcase_07 AC 3 ms
5,376 KB
testcase_08 AC 3 ms
5,376 KB
testcase_09 AC 3 ms
5,376 KB
testcase_10 AC 1 ms
5,376 KB
testcase_11 AC 2 ms
5,376 KB
testcase_12 AC 2 ms
5,376 KB
testcase_13 AC 1 ms
5,376 KB
testcase_14 AC 2 ms
5,376 KB
testcase_15 AC 3 ms
5,376 KB
testcase_16 AC 3 ms
5,376 KB
testcase_17 AC 2 ms
5,376 KB
testcase_18 AC 2 ms
5,376 KB
testcase_19 AC 2 ms
5,376 KB
testcase_20 AC 2 ms
5,376 KB
testcase_21 AC 1 ms
5,376 KB
testcase_22 AC 1 ms
5,376 KB
testcase_23 AC 2 ms
5,376 KB
testcase_24 AC 2 ms
5,376 KB
testcase_25 AC 2 ms
5,376 KB
testcase_26 AC 3 ms
5,376 KB
testcase_27 AC 4 ms
5,376 KB
testcase_28 AC 4 ms
5,376 KB
testcase_29 AC 3 ms
5,376 KB
testcase_30 AC 1 ms
5,376 KB
testcase_31 AC 1 ms
5,376 KB
testcase_32 AC 1 ms
5,376 KB
testcase_33 AC 2 ms
5,376 KB
testcase_34 AC 2 ms
5,376 KB
testcase_35 AC 3 ms
5,376 KB
testcase_36 AC 2 ms
5,376 KB
testcase_37 AC 3 ms
5,376 KB
testcase_38 AC 3 ms
5,376 KB
testcase_39 AC 2 ms
5,376 KB
testcase_40 AC 1 ms
5,376 KB
testcase_41 AC 1 ms
5,376 KB
testcase_42 AC 1 ms
5,376 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

local s = io.read()
if #s == 1 then
  print(s .. s)
  os.exit()
elseif #s == 2 then
  print(s .. s:sub(1, 1))
  os.exit()
end
local n = #s
local hn = math.floor(n / 2)
local f1 = s:sub(1, hn)
local f2 = s:sub(n - hn + 1, n):reverse()
if n % 2 == 1 then
  local ngpos = false
  for i = 1, hn do
    if f1:sub(i, i) ~= f2:sub(i, i) then
      ngpos = i
      break
    end
  end
  if not ngpos then
    print(f1 .. string.rep(s:sub(hn + 1, hn + 1), 2) .. f1:reverse())
    os.exit()
  end
  local mid = s:sub(hn + 1, hn + 1)
  local v = mid == f2:sub(hn, hn)
  for i = ngpos + 1, hn do
    if f1:sub(i, i) ~= f2:sub(i - 1, i - 1) then
      v = false break
    end
  end
  if v then
    print(f1 .. mid .. f2:sub(ngpos, hn):reverse() .. f1:sub(1, ngpos):reverse())
    os.exit()
  end
  v = mid == f1:sub(hn, hn)
  for i = ngpos + 1, hn do
    if f2:sub(i, i) ~= f1:sub(i - 1, i - 1) then
      v = false break
    end
  end
  if v then
    print(f2 .. mid .. f1:sub(ngpos, hn):reverse() .. f2:sub(1, ngpos):reverse())
  else
    print("NA")
  end
else
  local ngpos = false
  for i = 1, hn do
    if f1:sub(i, i) ~= f2:sub(i, i) then
      ngpos = i
      break
    end
  end
  if not ngpos then
    print(f1 .. "a" .. f1:reverse())
    os.exit()
  end
  local v = true
  for i = ngpos + 1, hn do
    if f1:sub(i, i) ~= f2:sub(i - 1, i - 1) then
      v = false
      break
    end
  end
  if v then
    print(f1 .. f2:sub(ngpos, hn):reverse() .. f1:sub(1, ngpos):reverse())
    os.exit()
  end
  v = true
  for i = ngpos + 1, hn do
    if f2:sub(i, i) ~= f1:sub(i - 1, i - 1) then
      v = false
      break
    end
  end
  if v then
    print(f2 .. f1:sub(ngpos, hn):reverse() .. f2:sub(1, ngpos):reverse())
  else
    print("NA")
  end
end
0