codevs1045

题目地址:http://codevs.cn/problem/1045/

代码:

var
i,n,js,c,k:longint;
a,b:array[1..10000]of longint;
s:string;
begin
readln(n);
readln(s);
fillchar(a,sizeof(a),0);
for i:=1 to length(s) do
begin
if s[i]>'9'
then
begin
case s[i] of
'a','A':a[i]:=10;
'b','B':a[i]:=11;
'c','C':a[i]:=12;
'd','D':a[i]:=13;
'e','E':a[i]:=14;
'f','F':a[i]:=15;
end;
end
else a[i]:=ord(s[i])-48;
end;
c:=length(s);
for i:=1 to c do
if a[i]<>a[c-i+1]
then break;
if i=c
then begin writeln('STEP=0');exit;end;
js:=0;
while js<30 do
begin
inc(js);
fillchar(b,sizeof(b),0);
for i:=1 to c do
begin
b[i]:=a[i]+a[c-i+1];
end;
k:=0;
while k<=c do
begin
k:=k+1;
if b[k]>n-1
then
begin
b[k+1]:=b[k+1]+b[k] div n;
b[k]:=b[k] mod n;
if k=c
then c:=c+1;
end;
end;
a:=b;
for i:=1 to c do
if a[i]<>a[c-i+1]
then break;
if i=c
then begin writeln('STEP=',js);exit;end;
end;
writeln('Impossible!');
end.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值