Pertimbangkan array bilangan bulat:
[1, 0, 9, 1, 3, 8]
Ada banyak cara untuk mem-partisi daftar ini menjadi sublists berturut-turut. Inilah tiga:
A: [[1, 0, 9], [1, 3, 8]]
B: [[1], [0, 9], [1, 3], [8]]
C: [[1, 0], [9, 1], [3, 8]]
Kami akan memanggil partisi Y dan memperbaiki partisi X lainnya jika X dapat diperoleh dari Y dengan menggabungkan beberapa sublistenya kembali bersama.
Begitu B
juga penyempurnaan A
: jika kita bergabung dengan dua yang pertama dan dua yang terakhir kembali bersama, kita dapatkan A
. Tapi C
ini bukan penyempurnaan A
: kita harus memisahkan 9
dan 1
untuk memulihkannya A
. Juga, partisi apa pun adalah perbaikan itu sendiri.
Perhatikan bahwa kami tidak diizinkan mengatur ulang setiap daftar atau elemen apa pun.
Tantangan
Diberikan dua partisi (daftar daftar bilangan bulat) X
dan Y
, tentukan apakah Y
penyempurnaan X
.
Anda mungkin menganggap bahwa partisi hanya akan berisi bilangan bulat dari 0
ke 9
, inklusif. Anda tidak boleh menganggap itu X
dan Y
merupakan partisi dari daftar yang sama (jika tidak, mereka juga bukan penyempurnaan dari satu sama lain). X
dan / atau Y
mungkin kosong tetapi tidak akan pernah berisi daftar kosong.
Anda dapat menulis suatu program atau fungsi, mengambil input melalui STDIN (atau alternatif terdekat), argumen baris perintah atau argumen fungsi dan mengeluarkan hasilnya melalui STDOUT (atau alternatif terdekat), nilai pengembalian fungsi atau parameter fungsi (keluar).
Input dapat diambil dalam format string atau daftar yang nyaman. Karena elemen-elemen tersebut hanya berupa bilangan bulat satu digit, Anda dapat memilih untuk menghilangkan pembatas di dalam sublist, tetapi pastikan bahwa 0
s yang terdepan mungkin. Anda dapat memilih untuk mengambil X
dan Y
dalam urutan yang berlawanan.
Output harus truthy jika Y
merupakan penyempurnaan dari X
dan falsy sebaliknya.
Kode Anda harus dapat menyelesaikan setiap kasus uji di bawah dalam 1 detik pada mesin desktop yang masuk akal. (Ini hanyalah pemeriksaan kewarasan untuk menghindari solusi brute force sederhana.)
Ini adalah kode golf, jadi jawaban tersingkat (dalam byte) menang.
Uji Kasus
Setiap test case adalah pada barisnya sendiri, ditulis sebagai X Y
. Saya menggunakan notasi larik GolfScript / CJam untuk menghemat ruang horisontal:
Benar:
[] []
[[0]] [[0]]
[[1 0 9 1 3 8]] [[1 0 9] [1 3 8]]
[[1 0 9 1 3 8]] [[1 0 9 1 3] [8]]
[[1 0 9 1 3 8]] [[1] [0] [9] [1] [3] [8]]
[[1 0 9] [1 3 8]] [[1 0 9] [1 3 8]]
[[1 0 9] [1 3 8]] [[1] [0 9] [1 3] [8]]
[[9 8 8 5 8 2 7] [5] [1 4] [2 0 0 6 0 8 4 2 6 4 2 3 7 8 7 3 9 5 7 9 8 2 9 5] [3 9 8] [7 1 4 9 7 4 5 9] [3 3 3] [9 0 7 8] [3 9 4 7 2 7 8 0 3 0] [8 2 2 7 3 9 3 2] [2 9 0 8 5 4 1 8 5 5 6 2 0 9 2 7 7 9 2 7] [3 6] [1 2 7 7 4 4 2 9]] [[9 8] [8] [5 8 2] [7] [5] [1 4] [2] [0 0 6] [0] [8 4 2] [6 4] [2] [3] [7 8] [7 3] [9] [5 7 9] [8 2] [9 5] [3] [9 8] [7 1 4] [9 7] [4 5 9] [3 3] [3] [9 0] [7 8] [3] [9] [4] [7 2] [7 8] [0] [3 0] [8 2] [2] [7 3] [9 3] [2] [2] [9] [0] [8 5 4] [1 8] [5 5] [6] [2 0] [9] [2] [7 7 9] [2 7] [3 6] [1 2] [7 7] [4 4 2] [9]]
Falsy:
[[0]] []
[[0]] [[1]]
[[1 0 9]] [[1 0 9] [1 3 8]]
[[1 0 9] [1 3 8]] [[1 0 9 1 3 8]]
[[1 0 9] [1 3 8]] [[1 0 9]]
[[1 0 9] [1 3 8]] [[1 0] [9]]
[[1 0 9] [1 3 8]] [[1 0] [9 1] [3 8]]
[[1] [0 9] [1 3] [8]] [[1 0 9] [1 3 8]]
[[9 8 8 5 8 2 7] [5] [1 4] [2 0 0 6 0 8 4 2 6 4 2 3 7 8 7 3 9 5 7 9 8 2 9 5] [3 9 8] [7 1 4 9 7 4 5 9] [3 3 3] [9 0 7 8] [3 9 4 7 2 7 8 0 3 0] [8 2 2 7 3 9 3 2] [2 9 0 8 5 4 1 8 5 5 6 2 0 9 2 7 7 9 2 7] [3 6] [1 2 7 7 4 4 2 9]] [[9 8] [8] [5 8 2] [7] [5 1] [4] [2] [0 0 6] [0] [8 4 2] [6 4] [2] [3] [7 8] [7 3] [9] [5 7 9] [8 2] [9 5] [3] [9 8] [7 1 4] [9 7] [4 5 9] [3 3] [3] [9 0] [7 8] [3] [9] [4] [7 2] [7 8] [0] [3 0] [8 2] [2] [7 3] [9 3] [2] [2] [9] [0] [8 5 4] [1 8] [5 5] [6] [2 0] [9] [2] [7 7 9] [2 7] [3 6] [1 2] [7 7] [4 4 2] [9]]
Papan peringkat
Berikut ini adalah Stack Snippet untuk menghasilkan leaderboard biasa dan gambaran umum pemenang berdasarkan bahasa.
Untuk memastikan bahwa jawaban Anda muncul, silakan mulai jawaban Anda dengan tajuk utama, menggunakan templat Penurunan harga berikut:
# Language Name, N bytes
di mana N
ukuran kiriman Anda. Jika Anda meningkatkan skor Anda, Anda dapat menyimpan skor lama di headline, dengan mencoretnya. Contohnya:
# Ruby, <s>104</s> <s>101</s> 96 bytes
<script>site = 'meta.codegolf'; postID = 5314; isAnswer = true; QUESTION_ID = 51719</script><script src='https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js'></script><script>jQuery(function(){var u='https://api.stackexchange.com/2.2/';if(isAnswer)u+='answers/'+postID+'?order=asc&sort=creation&site='+site+'&filter=!GeEyUcJFJeRCD';else u+='questions/'+postID+'?order=asc&sort=creation&site='+site+'&filter=!GeEyUcJFJO6t)';jQuery.get(u,function(b){function d(s){return jQuery('<textarea>').html(s).text()};function r(l){return new RegExp('<pre class="snippet-code-'+l+'\\b[^>]*><code>([\\s\\S]*?)</code></pre>')};b=b.items[0].body;var j=r('js').exec(b),c=r('css').exec(b),h=r('html').exec(b);if(c!==null)jQuery('head').append(jQuery('<style>').text(d(c[1])));if (h!==null)jQuery('body').append(d(h[1]));if(j!==null)jQuery('body').append(jQuery('<script>').text(d(j[1])))})})</script>
[[[1 0 9] [1 3 8]] [[1] [0 9] [1 3] [8]]]
atau[["109" "138"] ["1" "09" "13" "8"]]
menjadi format input yang dapat diterima?