আসুন 2-ডি অ্যারের অক্ষরের একটি চরিত্রের প্রতিবিম্ব পুনরায় সংজ্ঞায়নের মাধ্যমে শুরু করা যাক :
পৃথক ছোট বর্ণমালার বর্ণ সহ একটি বর্গক্ষেত্রে 2-ডি অ্যারে দেওয়া হয়েছে, ম্যাট্রিক্সের কোনও অক্ষরের প্রতিবিম্বটি এটি বর্গের কেন্দ্রের মধ্য দিয়ে সরাসরি চরিত্রের সাথে অদলবদল হিসাবে সংজ্ঞায়িত করে।
এইভাবে, চিঠির cমধ্যে একটি প্রতিচ্ছবি
abcde
fghij
klmno
pqrst
uvwxy
কনফিগারেশন ফলাফল হবে
abwde
fghij
klmno
pqrst
uvcxy
কারণ এবং cএবং wস্যুইচ করা হয়েছে।
আরও কয়েকটি উদাহরণ (উপরের মত একই মূল কনফিগারেশন সহ):
চরিত্রটি প্রতিবিম্বিত করতে eহবে
abcdu
fghij
klmno
pqrst
evwxy
চরিত্রটি প্রতিবিম্বিত mকরতে হবে
abcde
fghij
klmno
pqrst
uvwxy
চরিত্রটি প্রতিবিম্বিত করতে bহবে
axcde
fghij
klmno
pqrst
uvwby
চ্যালেঞ্জ
স্বতন্ত্র ছোট ছোট অক্ষরের সাথে অক্ষরের 2-ডি অ্যারে দেওয়া, একটি নির্দিষ্ট স্ট্রিংয়ের প্রতিটি অক্ষর দিয়ে যান এবং ম্যাট্রিক্সে এটি "প্রতিবিম্বিত" হন।
স্পেসিফিকেশন: স্ট্রিংয়ের a-zঅক্ষরগুলি হ'ল, বর্ণগুলি অনন্য, এবং অ্যারেটি কমপক্ষে 1x1 এবং সর্বাধিক 5x5 (স্পষ্টতই, ইংরেজী বর্ণমালায় কেবল 26 টি অক্ষর রয়েছে)) স্ট্রিংয়ের অক্ষরগুলি গ্যারান্টিযুক্ত 2-ডি অ্যারেতে স্ট্রিং সর্বাধিক 100 অক্ষর দীর্ঘ।
ইনপুট
একটি স্ট্রিং s, একটি পূর্ণসংখ্যা Nএবং তারপরে NxNঅক্ষরের একটি অ্যারে।
উদাহরণ
ইনপুট:
ac
2
ab
cd
আউটপুট:
dc
ba
* কারণ: প্রথমে, এর aসাথে প্রতিফলিত করুন d। তারপর, প্রতিফলিত cসঙ্গে bকারণ cইনপুট স্ট্রিং দ্বিতীয় চিঠি।
স্কোরিং
- আউটপুট যে কোনও সুবিধাজনক পদ্ধতিতে দেওয়া যেতে পারে ।
- হয় একটি সম্পূর্ণ প্রোগ্রাম বা একটি ফাংশন গ্রহণযোগ্য। যদি কোনও ফাংশন হয় তবে আপনি আউটপুটটি মুদ্রণের পরিবর্তে ফিরে আসতে পারেন।
- স্ট্যান্ডার্ড লুফোলগুলি নিষিদ্ধ।
- এটি কোড-গল্ফ তাই সাধারণ গল্ফিংয়ের সমস্ত নিয়ম প্রয়োগ হয় এবং সংক্ষিপ্ততম কোড (বাইটে) জয়ী হয়।
বর্তমান বিজয়ী
<style>body { text-align: left !important} #answer-list { padding: 10px; width: 290px; float: left; } #language-list { padding: 10px; width: 290px; float: left; } table thead { font-weight: bold; } table td { padding: 5px; }</style><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="language-list"> <h2>Shortest Solution 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> <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> <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><script>var QUESTION_ID = 163084; var ANSWER_FILTER = "!t)IWYnsLAZle2tQ3KqrVveCRJfxcRLe"; var COMMENT_FILTER = "!)Q2B_A2kjfAiU78X(md6BoYk"; var OVERRIDE_USER = 12012; var answers = [], answers_hash, answer_ids, answer_page = 1, more_answers = true, comment_page; function answersUrl(index) { return "https://api.stackexchange.com/2.2/questions/" + QUESTION_ID + "/answers?page=" + index + "&pagesize=100&order=desc&sort=creation&site=codegolf&filter=" + ANSWER_FILTER; } function commentUrl(index, answers) { return "https://api.stackexchange.com/2.2/answers/" + answers.join(';') + "/comments?page=" + index + "&pagesize=100&order=desc&sort=creation&site=codegolf&filter=" + COMMENT_FILTER; } function getAnswers() { jQuery.ajax({ url: answersUrl(answer_page++), method: "get", dataType: "jsonp", crossDomain: true, success: function (data) { answers.push.apply(answers, data.items); answers_hash = []; answer_ids = []; data.items.forEach(function(a) { a.comments = []; var id = +a.share_link.match(/\d+/); answer_ids.push(id); answers_hash[id] = a; }); if (!data.has_more) more_answers = false; comment_page = 1; getComments(); } }); } function getComments() { jQuery.ajax({ url: commentUrl(comment_page++, answer_ids), method: "get", dataType: "jsonp", crossDomain: true, success: function (data) { data.items.forEach(function(c) { if (c.owner.user_id === OVERRIDE_USER) answers_hash[c.post_id].comments.push(c); }); if (data.has_more) getComments(); else if (more_answers) getAnswers(); else process(); } }); } getAnswers(); var SCORE_REG = /<h\d>\s*([^\n,<]*(?:<(?:[^\n>]*>[^\n<]*<\/[^\n>]*>)[^\n,<]*)*),.*?(\d+)(?=[^\n\d<>]*(?:<(?:s>[^\n<>]*<\/s>|[^\n<>]+>)[^\n\d<>]*)*<\/h\d>)/; var OVERRIDE_REG = /^Override\s*header:\s*/i; function getAuthorName(a) { return a.owner.display_name; } function process() { var valid = []; answers.forEach(function(a) { var body = a.body; a.comments.forEach(function(c) { if(OVERRIDE_REG.test(c.body)) body = '<h1>' + c.body.replace(OVERRIDE_REG, '') + '</h1>'; }); var match = body.match(SCORE_REG); if (match) valid.push({ user: getAuthorName(a), size: +match[2], language: match[1], link: a.share_link, }); else console.log(body); }); valid.sort(function (a, b) { var aB = a.size, bB = b.size; return aB - bB }); var languages = {}; var place = 1; var lastSize = null; var lastPlace = 1; valid.forEach(function (a) { if (a.size != lastSize) lastPlace = place; lastSize = a.size; ++place; var answer = jQuery("#answer-template").html(); answer = answer.replace("{{PLACE}}", lastPlace + ".") .replace("{{NAME}}", a.user) .replace("{{LANGUAGE}}", a.language) .replace("{{SIZE}}", a.size) .replace("{{LINK}}", a.link); answer = jQuery(answer); jQuery("#answers").append(answer); var lang = a.language; lang = jQuery('<a>'+lang+'</a>').text(); languages[lang] = languages[lang] || {lang: a.language, lang_raw: lang.toLowerCase(), user: a.user, size: a.size, link: a.link}; }); var langs = []; for (var lang in languages) if (languages.hasOwnProperty(lang)) langs.push(languages[lang]); langs.sort(function (a, b) { if (a.lang_raw > b.lang_raw) return 1; if (a.lang_raw < b.lang_raw) return -1; return 0; }); for (var i = 0; i < langs.length; ++i) { var language = jQuery("#language-template").html(); var lang = langs[i]; language = language.replace("{{LANGUAGE}}", lang.lang) .replace("{{NAME}}", lang.user) .replace("{{SIZE}}", lang.size) .replace("{{LINK}}", lang.link); language = jQuery(language); jQuery("#languages").append(language); } }</script>