# ------------------- 可修改数字 -------------------
dividend = 1790
start = 590
end = 680
max_results = 10
# ---------------------------------------------------
count = 0
found = []
pairs = set() # 用来防止重复组合
# 1. 优先显示整除
for d in range(start, end + 1, 5):
if count >= max_results:
break
if dividend % d == 0:
print(f"{dividend} ÷ {d} = {dividend // d}")
print("---")
count += 1
found.append(d)
# 2. 再显示一位小数
for d in range(start, end + 1, 5):
if count >= max_results:
break
if d in found:
continue
if (dividend * 10) % d == 0:
print(f"{dividend} ÷ {d} = {dividend / d}")
print("---")
count += 1
found.append(d)
# 3. 平衡拆分 + 去重(不会出现反过来的重复)
for d in range(start, end + 1, 5):
if count >= max_results:
break
if d in found:
continue
for d2 in range(start, end + 1, 5):
if d == d2:
continue
# ✅ 关键:小的放前面,大的放后面,防止重复
a, b = sorted((d, d2))
if (a, b) in pairs:
continue
best = None
best_diff = 999999
max_a = int(dividend * 10 / d)
for a_val in range(1, max_a):
p1 = d * a_val / 10
p2 = dividend - p1
if p2 <= 0:
continue
if (p2 * 10) % d2 == 0:
val1 = a_val / 10
val2 = (p2 * 10) / d2 / 10
if diff < best_diff:
best_diff = diff
best = (val1, val2, int(p1), int(p2))
if best:
val1, val2, p1, p2 = best
print(f"{d}、{d2}")
print(f"{d}*{val1}={p1}")
print(f"{d2}*{val2}={p2}")
print("---")
pairs.add((a, b)) # 记录这组组合
count += 1
break
IyAtLS0tLS0tLS0tLS0tLS0tLS0tIOWPr+S/ruaUueaVsOWtlyAtLS0tLS0tLS0tLS0tLS0tLS0tCmRpdmlkZW5kID0gMTc5MApzdGFydCA9IDU5MAplbmQgPSA2ODAKbWF4X3Jlc3VsdHMgPSAxMAojIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQoKY291bnQgPSAwCmZvdW5kID0gW10KcGFpcnMgPSBzZXQoKSAgIyDnlKjmnaXpmLLmraLph43lpI3nu4TlkIgKCiMgMS4g5LyY5YWI5pi+56S65pW06ZmkCmZvciBkIGluIHJhbmdlKHN0YXJ0LCBlbmQgKyAxLCA1KToKICAgIGlmIGNvdW50ID49IG1heF9yZXN1bHRzOgogICAgICAgIGJyZWFrCiAgICBpZiBkaXZpZGVuZCAlIGQgPT0gMDoKICAgICAgICBwcmludChmIntkaXZpZGVuZH0gw7cge2R9ID0ge2RpdmlkZW5kIC8vIGR9IikKICAgICAgICBwcmludCgiLS0tIikKICAgICAgICBjb3VudCArPSAxCiAgICAgICAgZm91bmQuYXBwZW5kKGQpCgojIDIuIOWGjeaYvuekuuS4gOS9jeWwj+aVsApmb3IgZCBpbiByYW5nZShzdGFydCwgZW5kICsgMSwgNSk6CiAgICBpZiBjb3VudCA+PSBtYXhfcmVzdWx0czoKICAgICAgICBicmVhawogICAgaWYgZCBpbiBmb3VuZDoKICAgICAgICBjb250aW51ZQogICAgaWYgKGRpdmlkZW5kICogMTApICUgZCA9PSAwOgogICAgICAgIHByaW50KGYie2RpdmlkZW5kfSDDtyB7ZH0gPSB7ZGl2aWRlbmQgLyBkfSIpCiAgICAgICAgcHJpbnQoIi0tLSIpCiAgICAgICAgY291bnQgKz0gMQogICAgICAgIGZvdW5kLmFwcGVuZChkKQoKIyAzLiDlubPooaHmi4bliIYgKyDljrvph43vvIjkuI3kvJrlh7rnjrDlj43ov4fmnaXnmoTph43lpI3vvIkKZm9yIGQgaW4gcmFuZ2Uoc3RhcnQsIGVuZCArIDEsIDUpOgogICAgaWYgY291bnQgPj0gbWF4X3Jlc3VsdHM6CiAgICAgICAgYnJlYWsKICAgIGlmIGQgaW4gZm91bmQ6CiAgICAgICAgY29udGludWUKCiAgICBmb3IgZDIgaW4gcmFuZ2Uoc3RhcnQsIGVuZCArIDEsIDUpOgogICAgICAgIGlmIGQgPT0gZDI6CiAgICAgICAgICAgIGNvbnRpbnVlCgogICAgICAgICMg4pyFIOWFs+mUru+8muWwj+eahOaUvuWJjemdou+8jOWkp+eahOaUvuWQjumdou+8jOmYsuatoumHjeWkjQogICAgICAgIGEsIGIgPSBzb3J0ZWQoKGQsIGQyKSkKICAgICAgICBpZiAoYSwgYikgaW4gcGFpcnM6CiAgICAgICAgICAgIGNvbnRpbnVlCgogICAgICAgIGJlc3QgPSBOb25lCiAgICAgICAgYmVzdF9kaWZmID0gOTk5OTk5CgogICAgICAgIG1heF9hID0gaW50KGRpdmlkZW5kICogMTAgLyBkKQogICAgICAgIGZvciBhX3ZhbCBpbiByYW5nZSgxLCBtYXhfYSk6CiAgICAgICAgICAgIHAxID0gZCAqIGFfdmFsIC8gMTAKICAgICAgICAgICAgcDIgPSBkaXZpZGVuZCAtIHAxCiAgICAgICAgICAgIGlmIHAyIDw9IDA6CiAgICAgICAgICAgICAgICBjb250aW51ZQoKICAgICAgICAgICAgaWYgKHAyICogMTApICUgZDIgPT0gMDoKICAgICAgICAgICAgICAgIHZhbDEgPSBhX3ZhbCAvIDEwCiAgICAgICAgICAgICAgICB2YWwyID0gKHAyICogMTApIC8gZDIgLyAxMAogICAgICAgICAgICAgICAgZGlmZiA9IGFicyh2YWwxIC0gdmFsMikKCiAgICAgICAgICAgICAgICBpZiBkaWZmIDwgYmVzdF9kaWZmOgogICAgICAgICAgICAgICAgICAgIGJlc3RfZGlmZiA9IGRpZmYKICAgICAgICAgICAgICAgICAgICBiZXN0ID0gKHZhbDEsIHZhbDIsIGludChwMSksIGludChwMikpCgogICAgICAgIGlmIGJlc3Q6CiAgICAgICAgICAgIHZhbDEsIHZhbDIsIHAxLCBwMiA9IGJlc3QKICAgICAgICAgICAgcHJpbnQoZiJ7ZH3jgIF7ZDJ9IikKICAgICAgICAgICAgcHJpbnQoZiJ7ZH0qe3ZhbDF9PXtwMX0iKQogICAgICAgICAgICBwcmludChmIntkMn0qe3ZhbDJ9PXtwMn0iKQogICAgICAgICAgICBwcmludCgiLS0tIikKICAgICAgICAgICAgcGFpcnMuYWRkKChhLCBiKSkgICMg6K6w5b2V6L+Z57uE57uE5ZCICiAgICAgICAgICAgIGNvdW50ICs9IDEKICAgICAgICAgICAgYnJlYWs=