সিপিপি তে সর্ট এবং স্টেবল সর্ট ফাংশনের পার্থক্য

সিপিপি তো সর্ট আর স্টেবল সর্ট নামের দুটি পৃথক ফাংশন আছে। এই পোস্টের উদ্দেশ্য এদুটির পার্থক্য দেখানো,কিভাবে ব্যবহার করতে হয় শিখানো না। আজকে codeforces কনটেস্টে জিনিসটা মাথায় না থাকার কারণে একদম সহজ প্রবলেমে বিশাল ধরা খেয়েছি।

প্রবলেমটির লিংক:
http://www.codeforces.com/problemset/problem/63/A

এখানে বলা হয়েছে নিচের মত নামের লিস্ট দেয়া হবে:

6
Jack captain
Alice woman
Charlie man
Teddy rat
Bob child
Julia woman

এটাকে সর্ট করতে হবে এমন ভাবে যেন rat রা সবার সামনে আসে,তারপর woman আর child (এদের precedence সমান),তারপর man ও সবশেষে ক্যাপ্টেন। দুজনের precedence সমান হলে যাকে আগে ইনপুট দেয়া হয়েছে তাকে আগে রাখতে হবে। তাহলে আউটপুট হবে:

Teddy
Alice
Bob
Julia
Charlie
Jack

খুব সহজ সমস্যা,বেশ দ্রুত ৫মিনিটের মধ্যে কোড লিখে ফেললাম:

ভূল হবার সম্ভাবনা নেই ভেবে লক করে দিয়ে অন্যদের কোড দেখতে থাকলাম। সিস্টেম টেস্টের পর দেখি wrong answer,এত সহজ প্রবলেমে যা ছিল পুরাই অপ্রত্যাশিত। ভলিউমে সাবমিট করার পর যে কেসের জন্য ভূল হচ্ছিল দেখেই বুঝতে পারলাম সমস্যা কোথায়। কেসটা হলো:

20
Wswwcvvm woman
Btmfats rat
I rat
Ocmtsnwx man
Urcqv rat
Yghnogt woman
Wtyfc man
Wqle child
Ujfrelpu rat
Dstixj man
Ahksnio woman
Khkvaap woman
Sjppvwm rat
Egdmsv rat
Dank rat
Nquicjnw rat
Lh captain
Tdyaqaqln rat
Qtj rat
Tfgwijvq rat

আমার আউটপুট এসেছিল:

Tfgwijvq
Btmfats
I
Qtj
Urcqv
Tdyaqaqln
Nquicjnw
Dank
Ujfrelpu
Egdmsv
Sjppvwm
Khkvaap
Ahksnio
Wqle
Yghnogt
Wswwcvvm
Dstixj
Wtyfc
Ocmtsnwx
Lh

এটা অবশ্যই ভূল। শুরুতে Tfgwijvq এর জায়গায় btmfats থাকার কথা কারণ সেটা ইনপুটে আগে আছে।

এখানেই sort() আর stable_sort() এর পার্থক্য। পরেরটা input sequence টা ঠিক রাখে আগেরটা রাখেনা। stable_sort(e,e+N) লিখে কোডটি সাবমিট করার পরেই accepted হয়ে গেল যদিও যা ধরা খাওয়ার খেয়ে ফেলেছি। তবে বড় কোনো কনটেস্টে ধরা খাওয়ার থেকে এগুলোতে ধরা খেয়ে শেখা ভালো 🙂 ।

Print Friendly, PDF & Email

ফেসবুকে মন্তব্য

comments

Powered by Facebook Comments

7,328 times read (exlcuding bots)

7 thoughts on “সিপিপি তে সর্ট এবং স্টেবল সর্ট ফাংশনের পার্থক্য

  1. no sort is required actually!!
    i had solved it with normal procedure..

  2. এক প্রবলেম অনেক ভাবেই সলভ করা যেতে পারে :)। সর্ট করতে গিয়ে ধরা খেয়ে স্টেবল সর্টের ব্যাপারটা জেনেছি তাই ব্লগটি লেখা।

  3. ডিফারেন্সটা জেনে ভালো লাগলো । স্টেবল সর্ট এর কথা জানতাম তবে ইউজ করি নি কখোনো ? একটা প্রশ্ন ছিলো । সর্ট এর জায়গায় স্টেবল সর্ট ব্যবহার করলে কি নরমাল সর্টিং এর প্রব্লেম গুলোর এনসার গুলোর কোনো সমস্যা হবে ?? নাকি একই এন্সার আসবে ??

Leave a Reply

Your email address will not be published. Required fields are marked *