সূচকগুলির একটি তালিকা এবং শূন্য বা আরও পূর্ণসংখ্যার তালিকাগুলি দেওয়া, প্রথম ইনপুট থেকে মূল অগ্রাধিকার সহ আরোহণের ক্রমে সাজানো পূর্ণসংখ্যার তালিকা আউটপুট।
উদাহরণ
কীগুলি ইনপুট হতে দিন [1, 0, 2]
এবং তালিকাগুলি ইনপুট হোক [[5, 3, 4], [6, 2, 1], [5, 2, 1]]
। এই তালিকাগুলি তাদের দ্বিতীয় উপাদান অনুসারে বাছাই করা দরকার, তারপরে প্রথম উপাদান, তৃতীয় উপাদান, ক্রমবর্ধমান ক্রমে:
- প্রথমত, আমরা সূচীতে মানগুলি অনুসারে বাছাই করি
1
:[[6, 2, 1], [5, 2, 1], [5, 3, 4]]
- এরপরে, আমরা সূচকে মানগুলি ব্যবহার করে প্রথম সাজানো থেকে কোনও সম্পর্ক ভাঙ্গি
0
:[[5, 2, 1], [6, 2, 1], [5, 3, 4]]
- পরিশেষে, আমরা সূচকে ভ্লুগুলির সাথে কোনও অবশিষ্ট সম্পর্ক ভাঙ্গি
2
(এটি আসলে কোনও পরিবর্তন করে না, কারণ কোনও সম্পর্ক নেই) are
বিস্তারিত
- বাছাই স্থিতিশীল: যদি দুটি উপাদান প্রদত্ত বাছাইয়ের কীগুলির সাথে সম্মানের সাথে সমান তুলনা করে, তবে অবশ্যই আউটপুটে একই আপেক্ষিক ক্রমে থাকতে হবে। উদাহরণস্বরূপ, যদি
A
এবংB
প্রদত্ত সাজানোর কী অধীনে সমান হয়, এবং ইনপুট ছিল[..., A, ..., B, ...]
,A
সামনে স্থাপন করা আবশ্যকB
আউটপুটে। - একটি সাজানোর কী কখনই ইনপুট তালিকার একটিতে অ-অযৌক্তিক উপাদানটিকে উল্লেখ করে না।
- কোনও সাজানোর কী পুনরাবৃত্তি হবে না। সুতরাং,
[1, 2, 1]
বাছাই কীগুলির একটি বৈধ তালিকা নয়। - সাজানো কী দ্বারা রেফারেন্সযুক্ত কোনও উপাদান বাছাইয়ের ক্রমের সাথে যুক্ত হয় না। কেবলমাত্র প্রাথমিক আপেক্ষিক ক্রম এবং বাছাই কী দ্বারা রেফারেন্স করা উপাদানগুলির মানগুলি আউটপুট ক্রম নির্ধারণ করে।
- আপনি বাছাই করতে পারেন কি বাছাই কীগুলি শূন্য-সূচকযুক্ত বা এক-সূচকযুক্ত।
- বাছাই কীগুলিতে কোনও নেতিবাচক মান থাকবে না। যদি আপনি ওয়ান-ইনডেক্সিং ব্যবহার করতে চান, তবে বাছাই করা কীগুলিতে কোনও শূন্য থাকবে না।
- পূর্ণসংখ্যার মানগুলি আপনার ভাষার স্থানীয়-প্রতিনিধিত্বযোগ্য ব্যাপ্তির বেশি হবে না। যদি আপনার নির্বাচিত ভাষা স্থানীয়ভাবে নির্বিচারে-নির্ভুলতা পূর্ণসংখ্যার (পাইথনের মতো) সক্ষম হয় তবে মেমরির সীমাবদ্ধতার সাপেক্ষে কোনও পূর্ণসংখ্যা মান ইনপুটটিতে উপস্থিত হতে পারে।
রেফারেন্স বাস্তবায়ন (পাইথন 2)
#!/usr/bin/env python
keys = input()
lists = input()
print sorted(lists, key=lambda l:[l[x] for x in keys])
পরীক্ষার মামলা
বিন্যাস: keys lists -> output
। সমস্ত সাজানোর কীগুলি শূন্য-সূচকযুক্ত।
[1, 0, 2] [[5, 3, 4], [6, 2, 1], [5, 2, 1]] -> [[5, 2, 1], [6, 2, 1], [5, 3, 4]]
[1, 2] [[5, 3, 4], [6, 2, 1], [5, 2, 1]] -> [[6, 2, 1], [5, 2, 1], [5, 3, 4]]
[0, 1] [[1, 2], [2, 1]] -> [[1, 2], [2, 1]]
[1, 0] [[1, 2], [2, 1]] -> [[2, 1], [1, 2]]
[0] [[4], [10, 11, -88], [-2, 7]] -> [[-2, 7], [4], [10, 11, -88]]
[2] [[-1, -5, 8, -1, -4, -10, -5, 4, 4, 6, -8, 4, 2], [-7, 6, 2, -8, -7, 7, -3, 3, 0, -6, 1], [-9, 8, -5, -1, -7, -8, -5, -6, 5, -6, 6]] -> [[-9, 8, -5, -1, -7, -8, -5, -6, 5, -6, 6], [-7, 6, 2, -8, -7, 7, -3, 3, 0, -6, 1], [-1, -5, 8, -1, -4, -10, -5, 4, 4, 6, -8, 4, 2]]
[2, 1] [[9, 2, -2, -10, -6], [3, -4, -2]] -> [[3, -4, -2], [9, 2, -2, -10, -6]]
[2, 4, 8] [[5, -3, 4, -6, -1, -2, -2, -4, 5], [-2, -3, 6, -4, -1, -4, -4, -5, 8, 9, 9, -3, 3, -9, -3], [2, 0, 10, -10, -1, 2, -1, 5, -1, 10, -5], [-7, -8, -6, 7, 3, 8, 6, -7, -2, 0, -6, -4, 4, -3, 2, -3]] -> [[-7, -8, -6, 7, 3, 8, 6, -7, -2, 0, -6, -4, 4, -3, 2, -3], [5, -3, 4, -6, -1, -2, -2, -4, 5], [-2, -3, 6, -4, -1, -4, -4, -5, 8, 9, 9, -3, 3, -9, -3], [2, 0, 10, -10, -1, 2, -1, 5, -1, 10, -5]]
[1, 2, 3, 4, 5] [[-7, 3, -8, 3, 5, -1, 6, -6, 9, 8], [-9, -1, -7, -9, -10, -2, -8, -10, -10, -3], [5, 3, -6, -5, -4, -4, -8, 2], [9, -4, 1, -1, -3, -2], [-6, -10, 4, -10, 6, 6, -1, 3, 0, 0], [1, -2, -7, -6, -7, -7, -1, 0, -4, 3, 3], [7, -1, -7, 2, -2, 9, 7, 5, -6, -8], [1, -5, -3, -10, -7, 9, -8, -5, -1], [-9, 4, -1, -1, 2, 4]] -> [[-6, -10, 4, -10, 6, 6, -1, 3, 0, 0], [1, -5, -3, -10, -7, 9, -8, -5, -1], [9, -4, 1, -1, -3, -2], [1, -2, -7, -6, -7, -7, -1, 0, -4, 3, 3], [-9, -1, -7, -9, -10, -2, -8, -10, -10, -3], [7, -1, -7, 2, -2, 9, 7, 5, -6, -8], [-7, 3, -8, 3, 5, -1, 6, -6, 9, 8], [5, 3, -6, -5, -4, -4, -8, 2], [-9, 4, -1, -1, 2, 4]]
[8, 7, 3, 2, 4, 9, 1] [[8, -5, 1, -6, -1, -4, 6, 10, 10, 6, 9, 5], [4, -8, 6, -10, -2, -3, 2, -6, 9, 5, 4, 10, 2, 3], [10, -1, 3, 0, -4, 1, -5, -4, -1, -7, 9, -9, -1, -5, 7, 8, 9, 6, -3], [0, -9, -7, -2, 2, -5, 7, 4, 6, -4, 1, 8, -7, 10], [5, 6, -9, 0, -1, 5, 4, 7, 5, 10, 2, 5, 7, -9]] -> [[10, -1, 3, 0, -4, 1, -5, -4, -1, -7, 9, -9, -1, -5, 7, 8, 9, 6, -3], [5, 6, -9, 0, -1, 5, 4, 7, 5, 10, 2, 5, 7, -9], [0, -9, -7, -2, 2, -5, 7, 4, 6, -4, 1, 8, -7, 10], [4, -8, 6, -10, -2, -3, 2, -6, 9, 5, 4, 10, 2, 3], [8, -5, 1, -6, -1, -4, 6, 10, 10, 6, 9, 5]]