Cetak tetrasinya


16

Tetrasi, direpresentasikan sebagai a^^b, adalah eksponensial berulang. Misalnya 2^^3adalah 2^2^2, yaitu 16.

Diberi dua angka a dan b , cetak a^^b.

Uji kasus

1 2 -> 1
2 2 -> 4
5 2 -> 3125
3 3 -> 7625597484987
etc.

Notasi ilmiah dapat diterima.

Ingat, ini adalah , jadi kode dengan jumlah byte terkecil menang.


2
Angka seperti apa? Bilangan bulat positif?
xnor


9
Eksponensial adalah non-asosiatif. Anda harus memasukkan setidaknya satu tes cade dengan b> 2 .
Dennis

@Dennis3 3 -> 7625597484987
Gabriel Benamy

1
@RosLuP Tidak, 3^3^3secara otomatis berarti 3^(3^(3)). Lihat en.wikipedia.org/wiki/Order_of_operations , di mana dikatakan "eksponen bertumpuk diterapkan dari atas ke bawah, yaitu, dari kanan ke kiri."
Oliver Ni

Jawaban:


14

Dyalog APL, 3 byte

*/⍴

TryAPL.

Penjelasan

*/⍴  Input: b (LHS), a (RHS)
  ⍴  Create b copies of a
*/   Reduce from right-to-left using exponentation

1
Hei, seseorang yang mengalahkan @ Dennis! Sekarang itu jarang terjadi! (;: P
HyperNeutrino

10

J, 5 4 byte

^/@#

Ini secara harfiah adalah definisi tetrasi.

Pemakaian

   f =: ^/@#
   3 f 2
16
   2 f 1
1
   2 f 2
4
   2 f 5
3125
   4 f 2
65536

Penjelasan

^/@#  Input: b (LHS), a (RHS)
   #  Make b copies of a
^/@   Reduce from right-to-left using exponentation

Ok a ^^ b di atas terbalik b ^^ a ...
RosLuP

@RosLuP Ya, J dan APL mengevaluasi dari kanan ke kiri, jadi 2 ^ 2 ^ 2dievaluasi sebagai 2 ^ (2 ^ 2)dan seterusnya
mil

9

Haskell, 19 byte

a%b=iterate(a^)1!!b

Iterasi secara eksponensial mulai dari 1untuk menghasilkan daftar [1,a,a^a,a^a^a,...], kemudian ambil belemen ke-10.

Panjang yang sama secara langsung:

a%0=1;a%b=a^a%(b-1)

Titik bebas lebih lama:

(!!).(`iterate`1).(^)

9

Mathematica, 16 byte

Power@@Table@##&

Penjelasan

Table@##

Buat b salinan a.

Power@@...

Eksponensial.


8

Python, 30 byte

f=lambda a,b:b<1or a**f(a,b-1)

Menggunakan definisi rekursif.


5

Python, 33 byte

lambda a,b:eval('**'.join([a]*b))

Ini mengevaluasi ke fungsi yang tidak disebutkan namanya, yang mengambil representasi string dari angka dan angka. Sebagai contoh:

>>> f=lambda a,b:eval('**'.join([a]*b))
>>> f('5',2)
3125
>>>

Jika mencampur format input seperti ini tidak masuk hitungan, ada juga versi 38 byte ini:

lambda a,b:eval('**'.join([str(a)]*b))

2
Metode yang keren!
xnor


3

Perl, 19 byte

Termasuk +1 untuk -p

Berikan angka pada baris terpisah di STDIN

tetration.pl
2
3
^D

tetration.pl

#!/usr/bin/perl -p
$_=eval"$_**"x<>.1

3

R, 39 byte

Fungsi rekursif:

f=function(a,b)ifelse(b>0,a^f(a,b-1),1)

2

Elemen , 11 byte

__2:':1[^]`

Cobalah online!

Ini hanya eksponensial "langsung" dalam satu lingkaran.

__2:':1[^]`
__              take two values as input (x and y)
  2:'           duplicate y and send one copy to the control stack
     :          make y copies of x
      1         push 1 as the initial value
       [ ]      loop y times
        ^       exponentiate
          `     print result

2

JavaScript (ES7), 24 byte

f=(a,b)=>b?a**f(a,b-1):1

Versi ES6 adalah 33 byte:

f=(a,b)=>b?Math.pow(a,f(a,b-1)):1

Hemat 1 byte:f=a=>b=>b?a**f(a,b-1):1
programmer5000

2

dc, 35 29 byte:

?dsdsa?[ldla^sa1-d1<b]dsbxlap

Ini adalah program lengkap pertama saya di Indonesia dc.


1

Perl, 40 byte

map{$a=$ARGV[0]**$a}0..$ARGV[1];print$a;

Menerima dua bilangan bulat sebagai input ke fungsi dan menampilkan hasilnya


1
Gunakan popuntuk mendapatkan $ARGV[1], lalu gunakan "@ARGV"untuk mendapatkan $ARGV[0]. Gunakan saysebagai gantinya print(opsi -M5.010atau -Egratis). Tapi tetap saja, ARGVini sangat panjang. Sebuah -pprogram hampir selalu menang
Ton Hospel

1

Sebenarnya , 6 byte

n`ⁿ)`Y

Cobalah online!

Input diambil sebagai b\na( \nadalah baris baru)

Penjelasan:

n`ⁿ)`Y
n       a copies of b
 `ⁿ)`Y  while stack changes between each call (fixed-point combinator):
  ⁿ       pow
   )      move top of stack to bottom (for right-associativity)

1

CJam , 9 byte

q~)*{\#}*

Cobalah online!

Penjelasan

q~          e# Take input (array) and evaluate
  )         e# Pull off last element
   *        e# Array with the first element repeated as many times as the second
    {  }*   e# Reduce array by this function
     \#     e# Swap, power


1

Bahasa GameMaker, 52 50 byte

d=a=argument0;for(c=1;c<b;c++)d=power(a,d)return d

Ini adalah jawaban saya yang ke 300: o
Timtech

GameMaker wtf? lol
Seni Cukup Indah

@SimplyBeautifulArt Ya, dan sementara saya melakukannya saya akan melepas 2 byte untuk Anda.
Timtech

Lol, bagus. =) Miliki +1 saya, tampaknya cukup sederhana dan saya memahaminya.
Simply Beautiful Art

@SimplyBeautifulArt Appreciated
Timtech


0

Minkolang 0,15 , 12 11 byte

nnDI1-[;]N.

Coba di sini!

Penjelasan

nn             Read two integers from input
  D            Pop top of stack and duplicate next element that many times
   I1-         Push length of stack, minus 1
      [        Pop top of stack and repeat for loop that many times
       ;       Pop b, a and push a^b
        ]      Close for loop
         N.    Output as number and stop.

0

Racket 51 byte

(define ans 1)(for((i b))(set! ans(expt a ans)))ans

Tidak Terkumpul:

(define (f a b)
  (define ans 1)
  (for((i b))
    (set! ans
          (expt a ans)))
  ans)

Pengujian:

(f 1 2)
(f 2 2)
(f 5 2)
(f 3 3)

Keluaran:

1
4
3125
7625597484987

0

Scala, 45 byte

Seq.fill(_:Int)(_:Double)reduceRight math.pow

Tidak Terkumpul:

(a:Int,b:Double)=>Seq.fill(a)(b).reduceRight(math.pow)

Buat urutan as dengan belemen, dan terapkan math.powdari kanan ke kiri.



0

Java 7, 71 57 byte

double c(int a,int b){return b>0?Math.pow(a,c(a,b-1)):1;}

Tidak digabungkan & kode uji:

Coba di sini.

class M{
  static double c(int a, int b){
    return b > 0
            ? Math.pow(a, c(a, b-1))
            :1;
  }

  public static void main(String[] a){
    System.out.println(c(1, 2));
    System.out.println(c(2, 2));
    System.out.println(c(5, 2));
    System.out.println(c(3, 3));
  }
}

Keluaran:

1.0
4.0
3125.0
7.625597484987E12


0

05AB1E , 4 byte

sF¹m

Cobalah online!

s     # Swap input arguments.
 F    # N times...
  ¹m  # Top of the stack ^ the first argument.

3 byte jika argumen dapat ditukar:

F¹m

2 2 menghasilkan 16 bukan 4 = 2 ^ 2
RosLuP

a=5, b=2harus keluar 3125. Saya tidak yakin urutan apa yang Anda masukkan, tetapi bagaimanapun saya memasukkan 5 dan 2 saya mendapatkan hasil yang salah.
FlipTack

0

Bash, 50 byte

(dalam batas tipe data bash integer)

Golf

E() { echo $(($(printf "$1**%.0s" `seq 1 $2`)1));}

Penjelasan

Bangun ekspresi dengan printf, mis. E 2 5:

  2**2**2**2**2**1

lalu gunakan bash built-in ekspansi aritmatika untuk menghitung hasilnya

Uji

E 1 2
1

E 2 2
4

E 5 2
3125

E 3 3
7625597484987

0

Powershell, 68 Bytes

filter p ($a){[math]::Pow($a,$_)};iex (,$args[0]*$args[1]-join"|p ")

Ini adalah yang terpendek dari tiga pendekatan yang saya coba, secara keseluruhan tidak terlalu bagus, saya 100% yakin ada pendekatan yang lebih pendek tetapi beberapa hal yang saya coba entah bagaimana berakhir dengan byte yang sedikit lebih banyak.

PS C:\++\golf> (1,2),(2,2),(5,2),(3,3) | % {.\sqsq $_[0] $_[1]}
1
4
3125
7625597484987

Sayangnya Powershell tidak memiliki built-in ^atau **operator, atau itu akan menjadi jawaban 32/33 byte yang bersih, yaitu

iex (,$args[0]*$args[1]-join"^")


0

Aksioma 70 byte

l(a,b)==(local i;i:=1;r:=a;repeat(if i>=b then break;r:=a^r;i:=i+1);r)

ini kurang golf

l(a,b)==
  local i
  i:=1;r:=a;repeat(if i>=b then break;r:=a^r;i:=i+1)
  r


(3) ->  [l(1,2),l(2,2),l(5,2),l(3,3),l(4,3)]

     (3)
     [1, 4, 3125, 7625597484987,
      13407807929942597099574024998205846127479365820592393377723561443721764030_
       0735469768018742981669034276900318581864860508537538828119465699464336490_
       06084096
       ]
                                                   Type: List PositiveInteger

0

Bertanya-tanya , 21 byte

f\@@[#0?^#1f#1-#0 1?1

Menggunakan pendekatan rekursif. Pemakaian:

f\@@[#0?^#1f#1-#0 1?1];f 2 3

Solusi bonus, 22 byte

@@:^ -#0 1(genc ^#1)#1

Pendekatan yang agak tidak konvensional. Pemakaian:

t\@@+>#[^;#1]tk -#0 1rpt#1;t 2 3

Lebih mudah dibaca:

@@
  iget
    - #0 1
    (genc ^#1) #1

Dengan asumsi a^^b:

Menghasilkan daftar tak terbatas yang dititrasi a; karena a=2, daftar ini akan terlihat seperti [2 4 16 65536...]. Kemudian indeks pada b-1karena Wonder adalah indeks nol.


0

Clojure, 56 byte

(fn[a b](last(take a(iterate #(apply *(repeat % b))b))))

Mungkin ada cara yang lebih pendek via apply comp?

Dengan menggunakan situs kami, Anda mengakui telah membaca dan memahami Kebijakan Cookie dan Kebijakan Privasi kami.
Licensed under cc by-sa 3.0 with attribution required.