CUDDLE-Berechnung

19

Laut der Wikipedia-Seite über die Nummer 69 ist zu beachten, dass 69 2 = 4.761 und 69 3 = 328.509 zusammen alle Dezimalstellen verwenden. Die Zahl 69 ist tatsächlich die niedrigste Zahl, die diese Eigenschaft erfüllt.

Aus einem ähnlichen Grund ist 32.043 bemerkenswert: 32.043 2 = 1.026.753.849 verwendet alle Dezimalstellen.

Wenn wir weiterhin über Zahlen sprechen wollen, die auf diese Weise interessant sind, brauchen wir eine Notation.

Für die meisten ganzen Zahlen n , die Potenzen n 2 ,…, n k werden alle zehn Dezimalstellen (ohne führende Nullen) mindestens einmal für ausreichend große Werte von k verwendet . Wenn es existiert, bezeichnen wir die niedrigste solche k als CUDDLE ( CUmulative Decimal Digits, Least Exponent ) von n .

Aufgabe

Schreiben Sie ein Programm oder eine Funktion, die eine einzelne nicht negative Ganzzahl n als Eingabe akzeptiert und deren CUDDLE berechnet und zurückgibt .

Wenn n kein CUDDLE hat , können Sie alles andere als eine positive Ganzzahl zurückgeben, einschließlich eines Fehlers oder einer leeren Zeichenfolge, solange Ihr Code irgendwann anhält.

Testfälle

Die linke Spalte wird eingegeben, die rechte Spalte wird ausgegeben.

0 
1 
2          15
3          10
4          10
5          11
6          12
7           7
8           5
9           6
10 
11          7
12          6
13          6
14          7
15          9
16          5
17          7
18          4
19          5
20         15
26          8
60         12
69          3
128         3
150         9
200        15
32043       2
1234567890  3

Zusätzliche Regeln

  • Ihr Code muss für alle Eingaben bis zu 255 funktionieren .

    Beachten Sie, dass dies mit ziemlich großen Zahlen zu tun hat. 20 15 ist bereits größer als 2 64 .

  • Wenn Sie das Ergebnis drucken, kann ein Zeilenvorschub folgen.

  • Es gelten die Standardregeln für .

Dennis
quelle
14
Ich habe mich gefragt, wie wir von CUDDLE auf 69 gekommen sind, und finde es etwas beunruhigend, dass es mit Macht zu tun hat;)
Aaron
Wenn die Nummer kein CUDDLE hat, ist es in Ordnung, wenn das Programm stoppt ... irgendwann? (dh wenn der Integerzähler überläuft)
Türknauf
Für die erste zusätzliche Regel gilt außerdem: Bedeutet dies, dass Ihr Code für Zahlen> 255 funktionieren muss , wenn der Integer-Typ Ihrer Sprache diese speichern kann ?
Türklinke
@Doorknob Irgendwann ist alles in Ordnung, solange es tatsächlich anhält. Ich habe eine Obergrenze von 255 für den Eingang festgelegt. Immer noch einige ziemlich große Zahlen in die Berechnungen einbezogen ...
Dennis
1
Ich habe den Testfall hinzugefügt, 26->8weil es das kleinste Beispiel ist, in dem n^1include die falsche Antwort (von 6) liefert , einen Fehler, den ich in meinem Code gemacht habe.
xnor 10.10.15 Uhr

Antworten:

4

Pyth, 16 Bytes

hf<9l{=+k^QTtS15

Probieren Sie es online aus: Demo oder Test Suite

Wie andere Lösungen verwende ich 15 als Obergrenze. Ich glaube, dass dies auch das maximale CUDDLE ist . Ich habe alle Zahlen bis 10.000.000 getestet und es gibt keine Nummer mit einem CUDDLE größer als 15.

Zahlen mit einem CUDDLE > = 10 sind schon ziemlich selten. Die einzigen Zahlen mit einem CUDDLE von 15 sind die Zahlen 2*10^k. Es gibt keine Nummern mit einem CUDDLE von 14 oder 13, der CUDDLE 12 erscheint nur für die Nummern 6*10^k, der CUDDLE 11 nur für 5*10^k.

Ich denke, dieser Code funktioniert perfekt für jede natürliche Zahl.

Gibt eine Fehlermeldung aus, wenn es keine Lösung gibt.

Erläuterung:

hf<9l{=+k^QTtS15   implicit: Q = input number
                             k = empty string
            tS15   the list [2, 3, 4, ..., 15]
 f                 filter this list for elements T, which satisfy:
         ^QT          compute Q^T
       +k             k + ^ (converts to string implicitly)
      = k             save the result in k
    l{  k             length of set of k (number of different chars)
  <9                  test if 9 is smaller than ^
h                  print the first number in the filtered list
                   (throws error if empty)
Jakube
quelle
8

Python 2, 56

f=lambda n,i=2,s='L':len(set(s))>10or-~f(n,i+1,s+`n**i`)

Eine rekursive Lösung. Zählt Exponenten iab 2und sammelt die Potenzstellen n**iin der Zeichenkette s. Wenn salle zehn Ziffern vorhanden sind, wird zurückgegeben True, was gleich ist 1, und andernfalls wird rekursiv und addiert 1. Dies fiel kürzer aus als die Rückkehr i.

Das Aufrufen der Funktion auf eine Nummer ohne CUDDLE wird mit beendet Internal error: RangeError: Maximum call stack size exceeded. Zahlen bis zu 255dieser Ausgabe benötigen nie mehr als 15 Iterationen.

Aufgrund der nervigen Angewohnheit von Python 2 L, große Zahlen anzufügen, initialisieren wir die Ziffernfolge tatsächlich auf Lund überprüfen, ob die festgelegte Größe mindestens 11 beträgt. Python 3 spart 2 Zeichen, indem es dies nicht benötigt, verliert jedoch 3 Zeichen bei der Verwendung strvon Backticks. Python 3.5 spart mit dem Entpacken von Sätzen zwei weitere Zeichen und spart so einen Buchstaben mehr als Python 2:

f=lambda n,i=2,s='':len({*s})>9or-~f(n,i+1,s+str(n**i))
xnor
quelle
4

Ruby, 67 65 Zeichen

->n{s='';[*2..99].index{|i|(s+="#{n**i}").chars.uniq.size==10}+2}

Funktioniert nahezu augenblicklich für alle Testfälle, auch für diejenigen> 255.

Fehler für Zahlen ohne CUDDLE.

Erläuterung:

-> n {                         # define function with short lambda syntax
  s = ''                       # the string we are storing the numbers in
  [*2..99]                     # for all numbers from 2 to 99...
    .index {|i|                # find index of the number `i` for which...
      (s+="#{n**i}")           # after appending pow(n,i) to s...
        .chars.uniq.size==10}  # num of uniq chars in s is 10 (each digit)
  + 2                          # add 2, because our index starts from 2
}
Türknauf
quelle
3

CJam, 28 Bytes

LliG,2>f#{s+_&_}%:,A#)_)s\g*

Probieren Sie es online aus

Dies beruht auf der Tatsache, dass der CUDDLE (falls vorhanden) für den Eingabebereich niemals größer als 15 ist, wie dies zuerst von @xnor beobachtet wurde.

Es gibt wahrscheinlich eine bessere Möglichkeit, die Ausgabe für den Fall zu erstellen, dass es keine Lösung gibt. Ich werde aktualisieren, wenn mir etwas einfällt.

Erläuterung:

L     Push empty string, will be used for accumulating digits.
li    Get input and convert to integer.
G,    Build list of exponents [0 .. 15].
2>    Slice off first two values, to produce [2 .. 15].
f#    Apply power operator with all exponents to input.
{     Start loop over powers.
  s     Convert to string. We care about the digits here.
  +     Concatenate with previously found digits.
  _&    Uniquify using set intersection of digit list with itself.
  _     Copy for continued accumulation in next loop iteration.
}%    End of loop over powers. We'll have an extra copy of the last value here,
      but it does no harm so we just keep it.
:,    Apply length operator to accumulated digit lists.
A#    Find 10 in the list. The search result will correspond to the first power
      that resulted in 10 different accumulated digits. If not found, the result
      will be -1. Note that 0 corresponds to power 2, since that was the first
      power we used. So we need to add 2 to get the result, and check for -1.
)     Increment value. 0 now corresponds to no solution.
_     Copy this value. Will be used as multiplier to create empty string if 0.
)     Increment again, to get the +2 needed for the result.
s     Convert to string.
\     Swap once-incremented value to top, which is 0 for no solution, non-zero
      otherwise.
g     Signum to get 0/1 for no solution vs. solution.
*     Multiply with result string, to get empty string for no solution.
Reto Koradi
quelle
2

Mathematica, 103 Bytes

f=(d=DigitCount;x=1;y=d[0];For[n=0,!IntegerQ@Log10[#]&&MemberQ[y,0],++n,x*=#;y+=d[x]];Print[#,"\t",n])&

Es scheint, dass nur Potenzen von 10 keine CUDDLEs haben würden, daher werden sie übersprungen. Die Funktion speichert eine Liste der angezeigten Ziffern und stoppt, wenn keine Nullen mehr vorhanden sind.

Ausgabe:

1    0
2    15
3    10
4    10
5    11
6    12
7    7
8    5
9    6
10    0
11    7
12    6
13    6

quelle
Unterhaltsame Tatsache: Solange log_10(n)eine positive ganze Zahl irrational ist, kgibt es sie mso, dass die Dezimaldarstellung von mit n^mbeginnt k. Was bedeutet, dass das Überspringen der Potenzen von 10 (und 0) in Ordnung ist :)
Sp3000
2

JavaScript (ES6) 188

Nicht schlecht für eine Sprache, die auf 53-Bit-Ganzzahlen beschränkt ist.

Testen Sie das folgende Snippet in einem Browser, der EcmaScripts 6 implementiert, einschließlich Pfeilfunktionen und Spread-Operator (AFAIK Firefox).

f=n=>{for(p=1,d=[],v=n=[...n+''].reverse();++p<20;){v.map((a,i)=>n.map((b,j)=>r[j+=i]=a*b+~~r[j]),r=[],c=0),r=r.map(r=>(r+=c,c=r/10|0,d[r%=10]=r));v=c?[...r,c]:r;if(d.join``[9])return p;}}

// Less golfed
U=n=>{
// Arbitrary precision multiplication
  M=(A,B,R=[],c=0)=>
  (
    A.map((a,i)=>B.map((b,j)=>R[j+=i]=a*b+~~R[j])),
    R=R.map(r=>(r+=c,c=r/10|0,r%10)),
    c?[...R,c]:R
  );
  v=n=[...n+''].reverse();
  for(p=1,d=[];++p<20;)
  {
    v=M(n,v)
    
    v.map(c=>d[c]=c)
    if (d.join``[9])return p
  }  
}

// TEST
for(i=o='';++i<300;)o+=i+' : '+f(i)+'\n'
O.innerHTML=o
  
  
<pre id=O></pre>

edc65
quelle
2

PowerShell, 94 Byte

param($n,$s='')
2..99|%{$s+=[bigint]::Pow($n,$_);if(($s-split''|sort -U).Count-eq11){$_;break}}

(As a single line)

Nichts allzu Schlaues daran, aber das Weiterleiten an sort -U[nique]ist ein guter Weg, um die set()Funktionalität von Python für diese Art der Verwendung zu aktivieren, ohne explizit Elemente zu einer Hash-Tabelle hinzuzufügen.

param($n,$s='')                              # Take command line parameter.
2..99 |%{                                    # Loop from 2 to 99, inclusive.
    $s+=[bigint]::Pow($n,$_)                 # $n^Loopvar, concatenate to string.
    if (($s-split''|sort -U).Count-eq11) {   # Convert to unique-characters-array; count.
        $_;break                             # Print current loopvar and quit.
    }
}                                            # Otherwise, finish (silently).

z.B

PS C:\> .\CUDDLE-of-n.ps1 10

PS C:\> .\CUDDLE-of-n.ps1 12
6

PS C:\> .\CUDDLE-of-n.ps1 255
5
TessellatingHeckler
quelle
1

Gawk 4, 73 + 5 für Flags = 78 Bytes

{for(n=$0;a-1023&&++i<15;j=0)for($0*=n;j++<NF;)a=or(a,2^$j)}$0=i<15?++i:_

Für jede Ziffer, 0bis 9sie in die Potenzen der Eingabe eingeht, setzt sie das Bit, das 2^digitin repräsentiert a, bis die ersten 10 Ziffern gefunden wurden ( a == 1023 == 2^10-1) oder mehr als 15 Iterationen stattgefunden haben.

Muss mit einem leeren Feldtrenner und der -M-Flagge für große Zahlen aufgerufen werden.

echo 17 | awk -M '{for(n=$0;a-1023&&++i<15;j=0)for($0*=n;j++<NF;)a=or(a,2^$j)}$0=i<15?++i:_' FS=

Als ich damit herumspielte, fand ich die folgenden Sequenzen für die verschiedenen CUDDLEs:

2: 32043 32286 33144 35172 35337 35757 35853 37176 37905 38772 39147 39336 40545 42744 43902 44016 45567 45624 46587 48852 49314 49353 50706 53976 54918 55446 55524 55581 55626 56532 57321 58413 58455 58554 59403 60984 61575 61866 62679 62961 63051 63129 65634 65637 66105 66276 67677 68763 68781 69513 71433 72621 75759 76047 76182 77346 78072 78453 80361 80445 81222 81945 83919 84648 85353 85743 85803 86073 87639 88623 89079 89145 89355 89523 90144 90153 90198 91248 91605 95
3: 69 128 203 302 327 366 398 467 542 591 593 598 633 643 669 690 747 759 903 923 943 1016 1018 1027 1028 1043 1086 1112 1182 1194 1199 1233 1278 1280 1282 1328 1336 1364 1396 1419 1459 1463 1467 1472 1475 1484 1499 1508 1509 1519 1563 1569 1599 1602 1603 1618 1631 1633 1634 1659 1669 1687 1701 1712 1721 1737 1746 1767 1774 1778 1780 1791 1804 1837 1844 1869 1889 1895 1899 1903 1919 1921 1936 1956 1958 1960 1962 1973 1984 1985 1991 1994 1996 2003 2017 2019 2030 2033 2053 2075 2123 2126 2134 2157 2158 2159 2168 2175 2183
4: 18 54 59 67 71 84 93 95 97 108 112 115 132 139 144 147 148 152 156 159 169 172 174 178 179 180 181 182 184 195 196 213 214 215 216 221 223 227 228 232 234 235 239 241 242 248 265 266 267 270 272 273 279 281 285 287 294 298 299 306 311 312 314 315 316 323 326 332 336 338 342 343 353 354 356 361 362 364 365 368 369 379 388 391 393 395 396 397 403 412 413 416 416 42 431 434 439 442 443 444 448 451 452 453 454 455 457 459 463 466 469 472 473 477 479 482 484 489 493 494 496 503 507 508 509 515 517 523
5: 8 16 19 27 28 38 44 47 55 57 61 77 79 80 82 83 86 91 92 103 106 116 117 118 121 123 125 126 129 131 133 136 138 140 141 142 143 145 146 151 154 158 160 161 165 167 173 175 176 177 183 185 186 187 189 190 191 192 193 197 198 204 207 218 224 226 229 230 231 236 240 243 246 249 253 255 257 259 261 263 268 269 271 275 276 277 278 280 282 283 284 286 288 289 292 293 304 309 322 328 331 339 341 344 345 346 347 348 349 352 357 359 367 371 372 373 374 375 377 380 381 384 387 389 402 407 408 409 411 417 418 422 427
6: 9 12 13 22 23 24 33 36 37 39 42 43 45 46 49 51 53 58 62 66 72 73 75 78 81 88 90 94 98 107 109 114 119 120 122 127 130 134 137 149 153 155 162 163 164 166 168 170 194 199 206 211 212 217 219 220 222 225 233 237 238 244 247 252 254 256 262 264 274 291 295 296 301 308 317 319 321 324 325 330 333 334 337 351 355 358 360 370 376 378 382 383 385 386 390 394 399 401 404 405 406 415 420 421 424 425 429 430 433 435 438 446 450 460 471 476 478 488 490 498 502 504 506 510 513 514 519 530 539 548 556 578 620 628 631 634 636
7: 7 11 14 17 29 31 32 35 41 48 52 56 63 64 70 74 85 89 96 99 102 104 110 111 135 171 188 201 202 205 208 245 251 290 297 303 305 307 310 313 318 320 335 350 363 392 410 465 475 480 483 485 501 511 518 520 521 560 582 584 595 601 630 640 682 700 736 740 786 798 850 890 952 956 965 975 982 990 999 1002 1005 1011 1020 1040 1054 1100 1110 1171 1219 1313 1331 1350 1379 1414 1447 1468 1601 1707 1710 1735 1748 2001 2010 2020 2050 2080 2450 2510 2534 2641 2745 2900 2914 2955 2970 3030 3050 3070 3100 3130 3136 3180 3193 3200
8: 21 25 26 30 34 65 76 124 209 210 250 260 300 340 505 650 1004 1240 2002 2090 2100 2500 2600 2975 3000 3400 3944 4376 5050 6500 6885 7399 10040 12400 15483 20002 20020 20900 21000 25000 26000 29750 30000 34000 43760 50500 65000 68850 73990 
9: 15 68 101 150 1001 1010 1500 10001 10010 10100 15000 
10: 3 4 40 400 4000 40000 
11: 5 50 500 5000 50000 
12: 6 60 600 6000 60000 
15: 2 20 200 2000 20000
Cabbie407
quelle