前提・実現したいこと
pythonで下記の問題を解いておりましたが、どうしてもある入力に対して間違いを出力します
どこのロジックが間違っているか、ご教示いただけますでしょうか
問題はこちら
発生している問題・エラーメッセージ
入力例1, 2に対しては正しい出力になりますが、3番の入力例に対して正しい回答となりません
該当のソースコード
python
1def main(): 2 import math 3 a, b, c, d = map(int, input().split()) 4 5#a-bの間の数字の個数("全体の個数")を数える 6 kosuu = b - a + 1 7 8#c, d, c&dの最小公倍数と、a, bそれぞれの割り算の商を求めておく 9 a_c = a // c 10 a_d = a // d 11 b_c = b // c 12 b_d = b // d 13 14 lcm_cd = c/ math.gcd(c,d) * d 15 a_cd = a // lcm_cd 16 b_cd = b // lcm_cd 17 18#c, d, c&dの最小公倍数がa, bの間に何個あるか("約数の個数")を数える(aは「a以上」の条件から検討に入れるべき数字のため、aで割り切れる場合は約数の個数として含める) 19 if a % c == 0: 20 kosuu_c = b_c - a_c + 1 21 else: 22 kosuu_c = b_c - a_c 23 24 if a % d == 0: 25 kosuu_d = b_d - a_d + 1 26 else: 27 kosuu_d = b_d - a_d 28 29 if a % lcm_cd == 0: 30 kosuu_cd = b_cd - a_cd + 1 31 else: 32 kosuu_cd = b_cd - a_cd 33 34#全体の個数から約数の個数を引く。公倍数の約数の個数分多く引きすぎているため、足し戻す 35 print(int(kosuu - kosuu_c - kosuu_d +kosuu_cd)) 36 37 38 39 40if __name__ == "__main__": 41 main() 42
試したこと
約数の個数のあたりの処理がおかしいのかと思い、何度か境界となるあたりを検討したのですが、改善されませんでした
恐れ入りますが、お分かりになる方ご助力頂ければと思います
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/07/16 02:53