Skip to content

Instantly share code, notes, and snippets.

@betrue12
Last active June 24, 2018 13:11
Show Gist options
  • Save betrue12/68fec51db94c1b58e96440a487f621ca to your computer and use it in GitHub Desktop.
Save betrue12/68fec51db94c1b58e96440a487f621ca to your computer and use it in GitHub Desktop.
Snuke Numbers実験用スクリプト
# https://beta.atcoder.jp/contests/arc099/tasks/arc099_b
# N以下の範囲でn/S(n)を後ろから計算し、「その時点での最小値」であればすぬけ数ということにする。
# 探索範囲が限られているため、最後のほうの値は正しくない。
N = 10**8
def digitsum(num)
ret = 0
while num > 0
ret += num % 10
num /= 10
end
ret
end
ans = []
min = 10**20
N.downto(1) do |i|
val = i.to_f / digitsum(i)
if min >= val
ans.unshift(i)
min = val
end
end
p ans
#=> [1, 2, 3, 4, 5, 6, 7, 8, 9, 19, 29, 39, 49, 59, 69, 79, 89, 99, 199, 299, 399, 499, 599, 699, 799, 899, 999, 1099, 1199, 1299, 1399, 1499, 1599, 1699, 1799, 1899, 1999, 2999, 3999, 4999, 5999, 6999, 7999, 8999, 9999, 10999, 11999, 12999, 13999, 14999, 15999, 16999, 17999, 18999, 19999, 20999, 21999, 22999, 23999, 24999, 25999, 26999, 27999, 28999, 29999, 39999, 49999, 59999, 69999, 79999, 89999, 99999, 109999, 119999, 129999, 139999, 149999, 159999, 169999, 179999, 189999, 199999, 209999, 219999, 229999, 239999, 249999, 259999, 269999, 279999, 289999, 299999, 309999, 319999, 329999, 339999, 349999, 359999, 369999, 379999, 389999, 399999, 499999, 599999, 699999, 799999, 899999, 999999, 1099999, 1199999, 1299999, 1399999, 1499999, 1599999, 1699999, 1799999, 1899999, 1999999, 2099999, 2199999, 2299999, 2399999, 2499999, 2599999, 2699999, 2799999, 2899999, 2999999, 3099999, 3199999, 3299999, 3399999, 3499999, 3599999, 3699999, 3799999, 3899999, 3999999, 4099999, 4199999, 4299999, 4399999, 4499999, 4599999, 4699999, 4799999, 4899999, 4999999, 5999999, 6999999, 7999999, 8999999, 9999999, 10999999, 11999999, 12999999, 13999999, 14999999, 15999999, 16999999, 17999999, 18999999, 19999999, 20999999, 21999999, 22999999, 23999999, 24999999, 25999999, 26999999, 27999999, 28999999, 29999999, 30999999, 31999999, 32999999, 33999999, 34999999, 35999999, 36999999, 37999999, 38999999, 39999999, 40999999, 41999999, 42999999, 43999999, 44999999, 45999999, 46999999, 47999999, 48999999, 49999999, 50999999, 51999999, 52999999, 53999999, 54999999, 55999999, 56999999, 57999999, 58999999, 59999999, 69999999, 79999999, 89999999, 99999999, 100000000]
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment