কম্পিউটার

শেল সাজানোর জন্য পাইথন প্রোগ্রাম


যখন শেল সাজানোর প্রয়োজন হয়, তখন একটি ফাংশন সংজ্ঞায়িত করা হয় এবং এটি একটি তালিকা এবং তালিকার দৈর্ঘ্যকে আর্গুমেন্ট হিসেবে নেয়। এই তালিকাটি একটি নির্দিষ্ট সংখ্যক উপাদান পর্যন্ত সাজানো হয়েছে, যেখানে উপাদানের সংখ্যা সবচেয়ে বড় মান। এটি করা হয় যতক্ষণ না উপাদানের সংখ্যার মান সবচেয়ে ছোট হয়।

এটি তালিকার সমস্ত উপ-তালিকার জন্য করা হয়, এবং এই সমস্ত উপ-তালিকাগুলি সাজানো হয়৷

ভিন্নধর্মী মান (অর্থাৎ পূর্ণসংখ্যা, ফ্লোটিং পয়েন্ট, স্ট্রিং ইত্যাদির মতো যেকোনো ডেটা টাইপের ডেটা) সংরক্ষণ করতে একটি তালিকা ব্যবহার করা যেতে পারে।

নীচে একই -

এর একটি প্রদর্শন রয়েছে৷

উদাহরণ

def shell_sort(my_list, list_len):
   interval = list_len // 2
   while interval > 0:
      for i in range(interval, list_len):
         temp = my_list[i]
         j = i
         while j >= interval and my_list[j - interval] > temp:
            my_list[j] = my_list[j - interval]
            j -= interval
         my_list[j] = temp
      interval //= 2

my_list = [ 45, 31, 62, 12, 89, 5, 9, 8]
list_len = len(my_list)
print ("The list before sorting is :")
print(my_list)
shell_sort(my_list, list_len)
print ("\nThe list after performing shell sorting is :")
print(my_list)

আউটপুট

The list before sorting is :
[45, 31, 62, 12, 89, 5, 9, 8]

The list after performing shell sorting is :
[5, 8, 9, 12, 31, 45, 62, 89]

ব্যাখ্যা

  • 'shell_sort' নামের একটি পদ্ধতি সংজ্ঞায়িত করা হয়েছে, যা তালিকাকে এবং তালিকার দৈর্ঘ্যকে আর্গুমেন্ট হিসেবে নেয়।
  • 'ইন্টারভাল' ভেরিয়েবলটি '//' বিটওয়াইজ অপারেটর ব্যবহার করে সংজ্ঞায়িত করা হয়।
  • এটি ফ্লোর ডিভিশন সম্পাদন করে।
  • এটি মানকে নিকটতম পূর্ণ সংখ্যায় বৃত্তাকার করে।
  • তালিকাটি পুনরাবৃত্তি করা হয়েছে, এবং একটি অস্থায়ী পরিবর্তনশীল তৈরি করা হয়েছে।
  • 'ইন্টারভাল' ভেরিয়েবলকে তালিকার প্রতিটি সূচকের সাথে তুলনা করা হয় এবং তালিকার প্রতিটি উপাদানকে সাময়িক পরিবর্তনশীলের সাথে তুলনা করা হয়।
  • 'ইন্টারভাল' ভেরিয়েবল আবার ফ্লোর ডিভিশন করার জন্য ব্যবহার করা হয়।
  • তালিকাটি সংজ্ঞায়িত, এবং কনসোলে প্রদর্শিত হয়।
  • এই তালিকাটি এবং এর দৈর্ঘ্য অতিক্রম করে পদ্ধতিটিকে বলা হয়।
  • আউটপুট কনসোলে প্রদর্শিত হয়।

  1. পাইথনের অন্তর্বর্তী তালিকা থেকে দীর্ঘতম ব্যবধানের দৈর্ঘ্য খুঁজে বের করার প্রোগ্রাম

  2. পাইথনে sort()

  3. পাইথন প্রোগ্রামে নির্বাচন সাজান

  4. 3D তালিকা তৈরি করতে পাইথন প্রোগ্রাম।