結果
| 問題 | No.238 Mr. K's Another Gift |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2020-04-23 23:16:00 |
| 言語 | Lua (LuaJit 2.1.1734355927) |
| 結果 |
AC
|
| 実行時間 | 4 ms / 2,000 ms |
| コード長 | 1,743 bytes |
| コンパイル時間 | 57 ms |
| コンパイル使用メモリ | 5,120 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-10-14 02:43:28 |
| 合計ジャッジ時間 | 1,847 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 40 |
ソースコード
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