Terakhir kali ketika saya mencoba untuk membuat sesuatu yang mudah yang bukan duplikat, akhirnya menjadi terlalu sulit .. Jadi mudah-mudahan kali ini memang sesuatu yang bisa dicoba juga oleh pendatang baru.
Memasukkan:
Array / daftar dengan bilangan bulat / desimal. (Atau string yang mewakili array dengan bilangan bulat / desimal.)
Keluaran:
Lingkari angka-angka dan terapkan lima operan matematika berikut dalam urutan ini:
- Tambahan (
+
); - Pengurangan (
−
); - Perkalian (
*
atau×
atau·
); - Divisi Nyata / Kalkulator (
/
atau÷
); - Eksponensial (
^
atau**
).
(CATATAN: Simbol antara tanda kurung hanya ditambahkan sebagai klarifikasi. Jika bahasa pemrograman Anda menggunakan simbol yang sama sekali berbeda untuk operasi matematika dari contoh, maka tentu saja itu benar-benar dapat diterima.)
Teruskan sampai Anda mencapai akhir daftar, dan kemudian berikan hasil penjumlahan tersebut.
Aturan tantangan:
- Eksponensial dengan 0 (
n ^ 0
) harus menghasilkan 1 (ini juga berlaku untuk0 ^ 0 = 1
). - Tidak ada test case untuk pembagian dengan 0 (
n / 0
), jadi Anda tidak perlu khawatir tentang case-edge. - Jika array hanya berisi satu nomor, kami mengembalikannya sebagai hasilnya.
Aturan umum:
- Ini adalah kode-golf , jadi jawaban tersingkat dalam byte menang.
Jangan biarkan bahasa kode-golf mencegah Anda memposting jawaban dengan bahasa non-codegolf. Cobalah untuk memberikan jawaban sesingkat mungkin untuk bahasa pemrograman 'apa saja'. - Aturan standar berlaku untuk jawaban Anda, jadi Anda diperbolehkan menggunakan STDIN / STDOUT, fungsi / metode dengan parameter yang tepat, program lengkap. Panggilanmu.
- Celah default tidak diperbolehkan.
- Jika memungkinkan, silakan tambahkan tautan dengan tes untuk kode Anda.
Kasus uji:
[1,2,3,4,5] -> 0
-> 1 + 2 = 3
-> 3 - 3 = 0
-> 0 * 4 = 0
-> 0 / 5 = 0
[5,12,23,2,4,4,2,6,7] -> 539
-> 5 + 12 = 17
-> 17 - 23 = -6
-> -6 * 2 = -12
-> -12 / 4 = -3
-> -3 ^ 4 = 81
-> 81 + 2 = 83
-> 83 - 6 = 77
-> 77 * 7 -> 539
[-8,50,3,3,-123,4,17,99,13] -> -1055.356...
-> -8 + 50 = 42
-> 42 - 3 = 39
-> 39 * 3 = 117
-> 117 / -123 = -0.9512...
-> -0.9512... ^ 4 = 0.818...
-> 0.818... + 17 = 17.818...
-> 17.818... - 99 -> -81.181...
-> -81.181... * 13 = -1055.356...
[2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2] -> 256
-> 2 + 2 = 4
-> 4 - 2 = 2
-> 2 * 2 = 4
-> 4 / 2 = 2
-> 2 ^ 2 = 4
-> 4 + 2 = 6
-> 6 - 2 = 4
-> 4 * 2 = 8
-> 8 / 2 = 4
-> 4 ^ 2 = 16
-> 16 + 2 = 18
-> 18 - 2 = 16
-> 16 * 2 = 32
-> 32 / 2 = 16
-> 16 ^ 2 = 256
[1,0,1,0,1,0] -> 1
-> 1 + 0 = 1
-> 1 - 1 = 0
-> 0 * 0 = 0
-> 0 / 1 = 0
-> 0 ^ 0 = 1
[-9,-8,-1] -> -16
-> -9 + -8 = -17
-> -17 - -1 = -16
[0,-3] -> -3
-> 0 + -3 = -3
[-99] -> -99
n ^ 0 = 1
tapi 0 ^ n = 0
. Konflik diselesaikan dengan menetapkan n != 0
kedua aturan, tetapi kemudian tidak 0 ^ 0
terdefinisi. Namun, ada banyak hal yang cocok dengan matematika jika 0 ^ 0
didefinisikan 1
. Lihat Wikipedia untuk beberapa detail.