結果

問題 No.757 チャンパーノウン定数 (2)
ユーザー cielciel
提出日時 2018-12-02 03:23:28
言語 Crystal
(1.11.2)
結果
CE  
(最新)
AC  
(最初)
実行時間 -
コード長 842 bytes
コンパイル時間 1,845 ms
コンパイル使用メモリ 218,268 KB
最終ジャッジ日時 2024-04-27 02:37:49
合計ジャッジ時間 2,385 ms
ジャッジサーバーID
(参考情報)
judge4 / judge3
このコードへのチャレンジ
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、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