AtCoder Beginner Contest 146: C - Buy an Integer
Python3でこの問題を解いたのですがACがとれません。検索してみると二分探索法が最適解として紹介されていましたが自分のやっている方法で何が間違っているのか分からないので、どこを直せば良いか教えていただきたいです。
追記:
WAと判定されたのはborder01とmax01です。それ以外のテストケースではACでした。
###問題
ABC146: C問題
1以上10^9以下の整数が売ってある。
整数Nを買うには aN + bd(N) 円が必要。(d(N)はNの桁数)
所持金が x円 のとき、買うことのできる整数Nの最大値は?
1つも買えない場合は 0 を出力
1 <= a <= 10^9
1 <= b <= 10^9
1 <= x <= 10^18
a, b, x は整数
###基本方針
aN + bd(N) <= x を満たす最大のNを答えればいい。
式変形すると N <= (x - b*d(N))/a
d(N)に1から9を入れていき桁数が合う最大のものを答える。
Python
1from sys import stdin 2 3a, b, x = (int(i) for i in stdin.readline().rstrip().split()) 4 5# 所持金が一定以上の場合、最大値は常に10^9 6if ((10**9)*a + 9*b) <= x: 7 print(10**9) 8else: 9 ans = 0 10 # d(N)に1 → 9を順に代入 11 for i in range(1, 10): 12 temp = (x - (b*i))/a 13 # 所持金で買える最大値の桁数がd(N)と一致しているか調べる 14 if 10**(i-1) <= temp < (10**i): 15 ans = int(temp) 16 print(ans) 17
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/03/06 20:43