結果

問題 No.757 チャンパーノウン定数 (2)
ユーザー cielciel
提出日時 2018-12-02 03:23:28
言語 Crystal
(1.10.0)
結果
CE  
(最新)
AC  
(最初)
実行時間 -
コード長 842 bytes
コンパイル時間 969 ms
コンパイル使用メモリ 174,108 KB
最終ジャッジ日時 2023-09-13 09:50:54
合計ジャッジ時間 1,316 ms
ジャッジサーバーID
(参考情報)
judge15 / judge14
このコードへのチャレンジ(β)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。

コンパイルメッセージ
Showing last frame. Use --error-trace for full trace.

In Main.cr:35:5

 35 | d.times{num/=base}
        ^----
Error: undefined method 'times' for BigFloat (compile-time type is (BigFloat | BigInt))

ソースコード

diff #

#!/usr/bin/env crystal
require "big/big_int"
starting=1
base=BigInt.new(gets.not_nil!)
while (s=gets)!=nil
	n=BigInt.new(s.not_nil!,base: base)+(starting-2)
	digits=1
	expbase=BigInt.new("1")
	if false
		while (x=expbase*(digits*(base-1)))<=n
			digits+=1
			expbase*=base
			n-=x
		end
	else
		if false
			while digits*base**digits-(base**digits-1)/(base-1)<=n
				digits+=1
			end
		elsif true
			digits=1+(s.not_nil!.size.downto(0).find{|digits|
				z=base**digits;z*digits-(z-1)/(base-1)<=n
			}||0)
		else
			digits=(1..s.not_nil!.size).bsearch{|digits|
				z=base**digits;z*digits-(z-1)/(base-1)>n
			}||s.not_nil!.size
		end
		expbase=base**(digits-1)
		n-=(digits-1)*expbase-(expbase-1)/(base-1)
	end
	num=expbase+n/digits
	d=digits-1-n%digits
	if false
		d.times{num/=base}
		puts num%base
	else
		puts num.to_s(base)[-d-1]
	end
end
0