n * k = dd0d00d di mana d = ...?

14

Diberikan bilangan bulat positif n ≤ 500 :

  • Temukan bilangan bulat positif terkecil k sehingga semua digit dalam representasi desimal n * k adalah 0 atau d , dengan 1 ≤ d ≤ 9 .

  • Cetak atau kembalikan d dalam waktu kurang dari 30 detik (baca lebih lanjut tentang itu di bagian Klarifikasi dan aturan ).

Contoh mudah

Berikut adalah 30 nilai pertama dari d .

+----+-------+---------+---+    +----+-------+---------+---+
|  n |     k |   n * k | d |    |  n |     k |   n * k | d |
+----+-------+---------+---+    +----+-------+---------+---+
|  1 |     1 |       1 | 1 |    | 16 |     5 |      80 | 8 |
|  2 |     1 |       2 | 2 |    | 17 |   653 |   11101 | 1 |
|  3 |     1 |       3 | 3 |    | 18 |     5 |      90 | 9 |
|  4 |     1 |       4 | 4 |    | 19 |   579 |   11001 | 1 |
|  5 |     1 |       5 | 5 |    | 20 |     1 |      20 | 2 |
|  6 |     1 |       6 | 6 |    | 21 |    37 |     777 | 7 |
|  7 |     1 |       7 | 7 |    | 22 |     1 |      22 | 2 |
|  8 |     1 |       8 | 8 |    | 23 |  4787 |  110101 | 1 |
|  9 |     1 |       9 | 9 |    | 24 |    25 |     600 | 6 |
| 10 |     1 |      10 | 1 |    | 25 |     2 |      50 | 5 |
| 11 |     1 |      11 | 1 |    | 26 |    77 |    2002 | 2 |
| 12 |     5 |      60 | 6 |    | 27 |    37 |     999 | 9 |
| 13 |    77 |    1001 | 1 |    | 28 |    25 |     700 | 7 |
| 14 |     5 |      70 | 7 |    | 29 | 37969 | 1101101 | 1 |
| 15 |     2 |      30 | 3 |    | 30 |     1 |      30 | 3 |
+----+-------+---------+---+    +----+-------+---------+---+

Contoh yang tidak begitu mudah

Satu kekhasan dari tantangan ini adalah bahwa beberapa nilai jauh lebih sulit ditemukan daripada yang lain - setidaknya dengan pendekatan yang murni kasar. Di bawah ini adalah beberapa contoh n yang mengarah pada nilai tinggi k .

+-----+------------+---------------+---+    +-----+------------+---------------+---+
|   n |          k |         n * k | d |    |   n |          k |         n * k | d |
+-----+------------+---------------+---+    +-----+------------+---------------+---+
|  81 |   12345679 |     999999999 | 9 |    | 324 |   13717421 |    4444444404 | 4 |
| 157 |   64338223 |   10101101011 | 1 |    | 353 |   28615017 |   10101101001 | 1 |
| 162 |   13717421 |    2222222202 | 2 |    | 391 |  281613811 |  110111000101 | 1 |
| 229 |   43668559 |   10000100011 | 1 |    | 405 |   13717421 |    5555555505 | 5 |
| 243 |   13717421 |    3333333303 | 3 |    | 439 |   22781549 |   10001100011 | 1 |
| 283 |   35371417 |   10010111011 | 1 |    | 458 |   43668559 |   20000200022 | 2 |
| 299 |   33478599 |   10010101101 | 1 |    | 471 |   64338223 |   30303303033 | 3 |
| 307 |   32576873 |   10001100011 | 1 |    | 486 |   13717421 |    6666666606 | 6 |
| 314 |   64338223 |   20202202022 | 2 |    | 491 |  203871711 |  100101010101 | 1 |
| 317 | 3154574483 | 1000000111111 | 1 |    | 499 |   22244489 |   11100000011 | 1 |
+-----+------------+---------------+---+    +-----+------------+---------------+---+

Klarifikasi dan aturan

  • n * k akan selalu mengandung setidaknya satu digit d , tetapi mungkin tidak mengandung nol sama sekali.
  • Ini adalah , jadi kode terpendek dalam byte menang. Namun, program atau fungsi Anda harus dapat mengembalikan hasilnya untuk 1 ≤ n ≤ 500 dalam waktu kurang dari 30 detik pada perangkat keras kelas menengah.
  • Ingatlah bahwa beberapa nilai lebih sulit ditemukan daripada yang lain. Suatu program yang akan mencoba untuk memaksa nilai k tidak mungkin memenuhi batasan waktu (kasus uji yang baik adalah n = 317 ). Ada metode yang jauh lebih cepat untuk ditemukan d .

Tabel referensi

Semua nilai d untuk 1 ≤ n ≤ 500 tercantum di bawah ini.

n       | d
--------+--------------------------------------------------
001-025 | 1 2 3 4 5 6 7 8 9 1 1 6 1 7 3 8 1 9 1 2 7 2 1 6 5
026-050 | 2 9 7 1 3 1 8 3 2 7 9 1 2 3 4 1 6 1 4 9 2 1 6 7 5
051-075 | 3 4 1 9 5 7 1 2 1 6 1 2 9 8 5 6 1 4 3 7 1 9 1 2 3
076-100 | 4 7 6 1 8 9 2 1 4 5 2 3 8 1 9 1 4 3 2 5 6 1 7 9 1
101-125 | 1 6 1 8 7 2 1 9 1 1 1 7 1 2 5 4 9 2 7 6 1 2 3 4 5
126-150 | 6 1 8 3 1 1 6 7 2 9 8 1 6 1 7 1 2 1 9 5 2 7 4 1 3
151-175 | 1 8 9 7 5 4 1 2 1 8 7 2 1 4 3 2 1 8 1 1 3 4 1 6 7
176-200 | 8 3 2 1 9 1 2 1 8 5 6 1 4 9 1 1 6 1 2 3 7 1 9 1 2
201-225 | 3 2 7 4 5 2 9 8 1 7 1 4 1 2 5 9 7 2 3 2 1 2 1 7 9
226-250 | 2 1 4 1 1 3 8 1 6 5 4 3 7 1 6 1 2 3 4 7 6 1 8 3 5
251-275 | 1 6 1 2 3 8 1 6 7 2 9 2 1 6 5 7 3 4 1 9 1 8 3 2 5
276-300 | 6 1 2 9 7 1 2 1 4 5 2 7 9 1 1 3 4 1 7 5 8 9 2 1 3
301-325 | 7 2 3 8 5 6 1 4 3 1 1 8 1 2 9 4 1 2 1 8 1 7 1 4 5
326-350 | 2 1 8 7 3 1 4 3 2 5 8 1 2 3 2 1 6 1 8 3 2 1 4 1 7
351-375 | 9 8 1 6 5 4 7 2 1 9 1 2 3 4 5 2 1 8 9 1 7 6 1 2 3
376-400 | 8 1 9 1 2 3 2 1 6 7 2 9 4 1 3 1 7 1 2 5 9 1 2 7 4
401-425 | 1 6 1 4 5 2 1 8 1 1 3 4 7 9 5 8 1 2 1 6 1 2 3 8 5
426-450 | 2 7 4 3 1 1 9 1 7 3 4 1 6 1 4 3 2 1 4 5 2 3 7 1 9
451-475 | 1 4 3 2 5 8 1 2 9 2 1 6 1 8 3 2 1 6 7 1 3 8 1 6 5
476-500 | 7 3 2 1 6 1 2 3 4 5 6 1 8 3 7 1 6 1 2 9 8 7 6 1 5
Arnauld
sumber
1
Terinspirasi oleh (tetapi sangat berbeda dari) tantangan terakhir ini .
Arnauld
n = 6669666 -> d = 9
J42161217
Diagonal menarik dalam tabel itu.
James
@ James Memang. Pola akan muncul sedikit lebih jelas dengan memformat MOD 24. Dengan MOD 25, kita mendapatkan beberapa diagonal sebagai gantinya. :-)
Arnauld

Jawaban:

3

Jelly , 16 15 14 byte

²B€Ḍ9×þF%Þ¹ḢQS

Quadratic runtime (di bawah 25 detik pada TIO).

Cobalah online!

Versi alternatif, 15 byte

2ȷB€Ḍ9×þF%Þ¹ḢQS

Runtime konstan (sekitar 1 detik pada TIO).

Cobalah online!

Bagaimana itu bekerja

²B€Ḍ9×þF%Þ¹ḢQS  Main link. Argument: n

²               Take the square of n.
                This bound is high enough for all integers up to 500. 
                In fact, The highest value we need is 1387 for input 471, so
                2000 (2ȷ) is also enough (and a lot faster).

 B€             Binary; convert 1, ..., 4159 to base 2.
   Ḍ            Undecimal; convert each digit array from base 10 to integer.
                This generates the array A of all positive integers up to n²
                whose decimal representations consist entirely of 1's and 0's.
    9×þ         9 multiply table; for each x in A, yield [x, 2x, ..., 8x, 9x].
       F        Flatten; concatenate the resulting arrays, yielding the vector
                V. Note that V contains all numbers that match the regex ^d[0d]*$
                in base 10, in ascending order.
          ¹     Identity; yield n.
        %Þ      Sort the entries for V by their remainders modulo n. This places
                multiples of n at the beginning. The sorting algorithm in stable,
                so the first element of sorted V is the smallest multiple of n.
           Ḣ    Head; extract the first element.
            Q   Unique; deduplicate its digits in base 10. This yields [d, 0].
             S  Take the sum, yielding d.
Dennis
sumber
5

JavaScript (ES6), 83 byte

n=>{for(p=1;;p=k)for(d=0;d++<9;)for(k=p;k<p+p;k++)if(k.toString(2)*d%n<1)return d;}

Sekarang kembali 6untuk n=252! Saya mencoba pendekatan rekursif tetapi juga 83 byte dan gagal bagi saya untuk angka yang lebih sulit:

f=(n,p=1,d=1,k=p)=>k<p+p?k.toString(2)*d%n<1?d:f(n,p,d,k+1):d>8?f(n,p+p):f(n,p,d+1)
Neil
sumber
4

Mathematica, 103 100 97 byte

#&@@IntegerDigits[Sort[Join@@Table[Cases[FromDigits/@{0,i}~Tuples~13/#,_Integer],{i,9}]][[10]]#]&


menemukan 317 dalam 0,39 detik

Cobalah secara online salin / tempel kode, tambahkan [317] di akhir dan tekan shift + enter untuk menjalankan

-3 byte dari @JungHwan Min
-3 byte dari @Keyu Gan

J42161217
sumber
Anda dapat menyingkirkan *di *#, dan Tuples[{0,i},13]adalah{0,i}~Tuples~13
JungHwan Min
ya tentu saja.
J42161217
Oh, dan satu lagi: [[1]]pada akhirnya sama dengan meletakkan #&@@di awal
JungHwan Min
... dan kami berhasil mencapai 100! terima kasih untuk -3 byte
J42161217
Anda dapat menggunakan Join@@sebagai gantinyaFlatten@
Keyu Gan
2

Python 2/3, 129 128 127 byte

from itertools import*
lambda n:next(d for p in count()for d in range(1,10)for k in range(2**p,2*2**p)if d*int(bin(k)[2:])%n<1)

-1 byte: count(0)count()
-1 byte: ==0<1karena tidak boleh negatif

Score_Under
sumber
2

Jelly , 21 byte

9Rṭ€0ṗ€⁴ẎḌḍ@Ðf⁸ṢDFḟ0Ḣ

Tautan monadik yang mengembalikan nomor ATAU program lengkap yang mencetaknya.

Brute-forcer dengan rentang terbatas yang membutuhkan waktu kurang dari 20 detik untuk setiap 1 ≤ n ≤ 500 (kurang dari 3 detik untuk biaya kode 1 byte - ganti dengan 13).

Cobalah online!

Bagaimana?

9Rṭ€0ṗ€⁴ẎḌḍ@Ðf⁸ṢDFḟ0Ḣ - Link: number, n
9R                    - range of 9 = [1,2,3,4,5,6,7,8,9]
  ṭ€0                 - tack €ach to 0 -> [[0,1],[0,2],[0,3],[0,4],[0,5],[0,6],[0,7],[0,8],[0,9]]
       ⁴              - literal 16
     ṗ€               - Cartesian product for €ach
        Ẏ             - tighten (flatten by 1 level)
         Ḍ            - covert from decimal list to number (vectorises)
              ⁸       - chain's left argument (n)
            Ðf        - filter keep items for which this yields a truthy value:
          ḍ@          -   divisible? with swapped @rguments
               Ṣ      - sort
                D     - convert to decimal list (vectorises)
                 F    - flatten into a single list
                  ḟ0  - filter out zeros
                    Ḣ - head (get the first value)
Jonathan Allan
sumber
2

PHP , 87 byte

for(;++$i<5e3;)for($n=10;$d=--$n*decbin($i);)($y&&$d>$y)|$d%$argn?:$x=$n.!$y=$d;echo$x;

Cobalah online!

PHP , 89 byte

for(;++$i<5e3;)for($n=10;$d=--$n*decbin($i);)$d%$argn?:$r[$d]=$n;krsort($r);echo end($r);

Cobalah online!

Jörg Hülsermann
sumber