質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

2065閲覧

ABC146-C-Buy an Integer PythonでACがとれない

nakano_desu

総合スコア7

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

1クリップ

投稿2020/03/06 13:14

編集2020/03/06 15:06

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

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

最初はここ

Python

1if ((10**9)*a + 9*b) <= x: 2 print(10**9)

10**9は10桁なので10*bを足さないといけません。


次に

Python

1temp = (x - (b*i))/a

Pythonでは'/'で割り算を行うと浮動小数点での計算になります。そのためxのように10**18レベルの数を扱うと誤差が出ます。

Text

1999999999 1 999999998000000009(== 999,999,999 * 999,999,999 + 8)

これの解は999999998ですが誤差で999999999になります。


もう一つはここ

Python

1 if 10**(i-1) <= temp < (10**i): 2 ans = int(temp)

Text

11 10 20

入力として上の例が与えられた場合、9が出力されるべきですが、i = 1 の時、temp = 10となりここではじかれて、i = 2の時、temp = 0となりまた弾かれます。結果ansには一度も代入されることなく、0が出力されます。

投稿2020/03/06 19:30

yudedako67

総合スコア2047

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

nakano_desu

2020/03/06 20:43

/でfloatになるのは知ってましたが誤差のことは知りませんでした。 3つ目はd(N)とNを切り離して考えたのがあまり良くなかったぽいですね。 丁寧な回答ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問