สนามกอล์ฟที่ง่ายต่อการเริ่มต้นสัปดาห์! คุณกำลังได้รับสามอาร์เรย์ที่: อาร์เรย์ฐาน B
ที่ค่าอาร์เรย์ V
และอาร์เรย์ดัชนี I
คุณควรผลิตอาร์เรย์อื่นที่ค่าจากV
จะแทรกเข้าไปในดัชนีที่กำหนดโดยB
I
นี่คือตัวอย่าง:
Base: [5, 1, 4, 1, 3]
Values: [0, 0, 7]
Indices: [5, 0, 3]
ดัชนีชี้ไปที่ตำแหน่งต่อไปนี้ในอาร์เรย์ฐาน:
[ 5, 1, 4, 1, 3 ]
^ ^ ^
0 3 5
ดังนั้นการแทรกองค์ประกอบที่สอดคล้องกันจากอาร์เรย์ค่าผลลัพธ์ควรเป็น:
[0, 5, 1, 4, 7, 1, 3, 0]
กฎระเบียบ
คุณอาจจะเขียนโปรแกรมหรือฟังก์ชั่นการป้อนข้อมูลผ่านทาง STDIN (หรือทางเลือกที่ใกล้เคียงที่สุด) อาร์กิวเมนต์บรรทัดคำสั่งหรือข้อโต้แย้งฟังก์ชั่นและการส่งออกผลผ่าน STDOUT (หรือทางเลือกที่ใกล้เคียงที่สุด) ส่งคืนค่าฟังก์ชั่นหรือโดยการปรับเปลี่ยนอาร์เรย์ที่กำหนดเป็นB
พารามิเตอร์ .
หากการส่งของคุณเป็นฟังก์ชั่นI
และV
สามารถแก้ไขได้ในทางใดทางหนึ่งเช่นเดียวกับB
ถ้ามันไม่ได้ใช้สำหรับการส่งออก
คุณอาจทำการสันนิษฐานต่อไปนี้เกี่ยวกับอินพุต:
- องค์ประกอบทั้งหมดของอาร์เรย์ฐานและค่าจะเป็นจำนวนเต็มไม่เป็นลบ
- อาร์เรย์ที่มีค่าจะมีองค์ประกอบได้มากกว่าหนึ่งรายการมากกว่าอาร์เรย์ฐาน
- อาร์เรย์ค่าและอาร์เรย์ดัชนีจะมีจำนวนองค์ประกอบเท่ากัน
- อาร์เรย์ดัชนีจะไม่มีดัชนีซ้ำและดัชนีทั้งหมดจะอยู่ในช่วง
- อาร์เรย์ฐานและค่าอาจมีองค์ประกอบที่ซ้ำกัน
- อาร์เรย์ใด ๆ หรือทั้งหมดอาจว่างเปล่า
- คุณต้องไม่คิดว่าจะมีการจัดทำดัชนีตามลำดับใด ๆ
- คุณอาจได้รับอินพุตและสร้างเอาต์พุตในรูปแบบสตริงหรือรายการที่สะดวกและชัดเจน คุณอาจเลือกที่จะรับสามอาร์เรย์ในลำดับที่แตกต่างกัน
- คุณสามารถเลือกระหว่างการจัดทำดัชนีแบบ 0 และ 1
นี่คือรหัสกอล์ฟดังนั้นคำตอบที่สั้นที่สุด (เป็นไบต์) ชนะ
กรณีทดสอบ
กำหนดในรูปแบบB V I => Result
สำหรับการจัดทำดัชนีแบบ0 หากคุณกำลังใช้การจัดทำดัชนีแบบ 1 ให้เพิ่มองค์ประกอบของอาร์เรย์ที่สามด้วย 1
[] [] [] => []
[] [1] [0] => [1]
[1,2] [] [] => [1,2]
[1,2] [3] [0] => [3,1,2]
[1,2] [3] [1] => [1,3,2]
[1,2] [3] [2] => [1,2,3]
[0,0,0] [1,1,1,1] [0,1,2,3] => [1,0,1,0,1,0,1]
[5,1,4,1,3] [0,0,7] [5,0,3] => [0,5,1,4,7,1,3,0]
[1,2,3,4] [4,3,2,1] [4,0,3,1] => [3,1,1,2,3,2,4,4]
แจ้งให้เราทราบหากคุณเจอกรณีขอบที่น่าสนใจอื่น ๆ และฉันจะเพิ่มพวกเขา
ลีดเดอร์บอร์ด
นี่คือตัวอย่างข้อมูลเพื่อสร้างทั้งกระดานผู้นำปกติและภาพรวมของผู้ชนะตามภาษา
เพื่อให้แน่ใจว่าคำตอบของคุณปรากฏขึ้นโปรดเริ่มคำตอบด้วยหัวข้อโดยใช้เทมเพลต Markdown ต่อไปนี้:
# Language Name, N bytes
ที่N
มีขนาดของส่งของคุณ หากคุณปรับปรุงคะแนนของคุณคุณสามารถเก็บคะแนนเก่าไว้ในพาดหัวโดยการตีพวกเขาผ่าน ตัวอย่างเช่น
# Ruby, <s>104</s> <s>101</s> 96 bytes
var QUESTION_ID=50369;function answersUrl(e){return"http://api.stackexchange.com/2.2/questions/"+QUESTION_ID+"/answers?page="+e+"&pagesize=100&order=desc&sort=creation&site=codegolf&filter="+ANSWER_FILTER}function getAnswers(){jQuery.ajax({url:answersUrl(page++),method:"get",dataType:"jsonp",crossDomain:!0,success:function(e){answers.push.apply(answers,e.items),e.has_more?getAnswers():process()}})}function shouldHaveHeading(e){var a=!1,r=e.body_markdown.split("\n");try{a|=/^#/.test(e.body_markdown),a|=["-","="].indexOf(r[1][0])>-1,a&=LANGUAGE_REG.test(e.body_markdown)}catch(n){}return a}function shouldHaveScore(e){var a=!1;try{a|=SIZE_REG.test(e.body_markdown.split("\n")[0])}catch(r){}return a}function getAuthorName(e){return e.owner.display_name}function process(){answers=answers.filter(shouldHaveScore).filter(shouldHaveHeading),answers.sort(function(e,a){var r=+(e.body_markdown.split("\n")[0].match(SIZE_REG)||[1/0])[0],n=+(a.body_markdown.split("\n")[0].match(SIZE_REG)||[1/0])[0];return r-n});var e={},a=1,r=null,n=1;answers.forEach(function(s){var t=s.body_markdown.split("\n")[0],o=jQuery("#answer-template").html(),l=(t.match(NUMBER_REG)[0],(t.match(SIZE_REG)||[0])[0]),c=t.match(LANGUAGE_REG)[1],i=getAuthorName(s);l!=r&&(n=a),r=l,++a,o=o.replace("{{PLACE}}",n+".").replace("{{NAME}}",i).replace("{{LANGUAGE}}",c).replace("{{SIZE}}",l).replace("{{LINK}}",s.share_link),o=jQuery(o),jQuery("#answers").append(o),e[c]=e[c]||{lang:c,user:i,size:l,link:s.share_link}});var s=[];for(var t in e)e.hasOwnProperty(t)&&s.push(e[t]);s.sort(function(e,a){return e.lang>a.lang?1:e.lang<a.lang?-1:0});for(var o=0;o<s.length;++o){var l=jQuery("#language-template").html(),t=s[o];l=l.replace("{{LANGUAGE}}",t.lang).replace("{{NAME}}",t.user).replace("{{SIZE}}",t.size).replace("{{LINK}}",t.link),l=jQuery(l),jQuery("#languages").append(l)}}var ANSWER_FILTER="!t)IWYnsLAZle2tQ3KqrVveCRJfxcRLe",answers=[],page=1;getAnswers();var SIZE_REG=/\d+(?=[^\d&]*(?:<(?:s>[^&]*<\/s>|[^&]+>)[^\d&]*)*$)/,NUMBER_REG=/\d+/,LANGUAGE_REG=/^#*\s*([^,]+)/;
body{text-align:left!important}#answer-list,#language-list{padding:10px;width:290px;float:left}table thead{font-weight:700}table td{padding:5px}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script><link rel="stylesheet" type="text/css" href="//cdn.sstatic.net/codegolf/all.css?v=83c949450c8b"><div id="answer-list"> <h2>Leaderboard</h2> <table class="answer-list"> <thead> <tr><td></td><td>Author</td><td>Language</td><td>Size</td></tr></thead> <tbody id="answers"> </tbody> </table></div><div id="language-list"> <h2>Winners by Language</h2> <table class="language-list"> <thead> <tr><td>Language</td><td>User</td><td>Score</td></tr></thead> <tbody id="languages"> </tbody> </table></div><table style="display: none"> <tbody id="answer-template"> <tr><td>{{PLACE}}</td><td>{{NAME}}</td><td>{{LANGUAGE}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr></tbody></table><table style="display: none"> <tbody id="language-template"> <tr><td>{{LANGUAGE}}</td><td>{{NAME}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr></tbody></table>
NULL
อาเรย์ที่ว่างเปล่าสำหรับภาษาที่อาเรย์ที่ว่างอยู่คือNULL
อะไร?