কম্পিউটার

পাইথনে গাণিতিক ক্রম থেকে অপসারিত শব্দ খুঁজে বের করার প্রোগ্রাম


ধরুন আমাদের কাছে n-1 গাণিতিক ক্রম পদ ধরে nums নামে একটি অ্যারে আছে। সংখ্যার প্রথম বা শেষ উপাদান ছাড়া একটি উপাদান আগে মুছে ফেলা হয়েছিল। আমাদের সরানো নম্বর খুঁজে বের করতে হবে।

সুতরাং, যদি ইনপুটটি সংখ্যার মত হয় =[5, 7, 11, 13], তাহলে আউটপুট হবে 9 কারণ, আইটেমগুলি 2i+5 সূত্র অনুসরণ করছে, তাই i =2 এর জন্য এটি হবে 2*2 + 5 =9 যা অনুপস্থিত।

এটি সমাধান করতে, আমরা এই পদক্ষেপগুলি অনুসরণ করব -

  • যদি সংখ্যার আকার 2 এর সমান হয়, তাহলে

    • (সংখ্যায় উপস্থিত সমস্ত উপাদানের যোগফল)/2

      এর রিটার্ন ফ্লোর
  • যদি nums[0] nums[1] এর মত হয়, তাহলে/p>

    • রিটার্ন সংখ্যা[0]

  • নিম্ন :=সংখ্যা[0]

  • উপরের :=সংখ্যার শেষ উপাদান

  • ব্যবধান :=তল (উপরের - নীচের) / সংখ্যার আকার

  • পয়েন্টার :=সংখ্যার আকারের মেঝে / 2

  • বাম :=0

  • ডান:=সংখ্যার আকার - 1

  • যখন বাম ডানের মতো নয়, তখন করুন

    • যদি nums[pointer] nums[0] + interval * pointer এর মত না হয়, তাহলে

      • যদি nums[pointer - 1] nums[0] + interval *(pointer - 1) এর মত হয়, তাহলে

        • রিটার্ন সংখ্যা[0] + ইন্টারভাল * পয়েন্টার

      • অন্যথায়,

        • ডান:=পয়েন্টার

        • পয়েন্টার :=ফ্লোর অফ(বাম + ডান) / 2

    • অন্যথায়,

      • যদি ডান - বাম 1 এর মত হয়, তাহলে

        • পয়েন্টার :=ডান

      • অন্যথায়,

        • বাম :=পয়েন্টার

        • পয়েন্টার :=ফ্লোর অফ (বাম + ডান) / 2

উদাহরণ

আসুন আরও ভালভাবে বোঝার জন্য নিম্নলিখিত বাস্তবায়ন দেখি

def solve(nums):
   if len(nums) == 2:
      return sum(nums) // 2

   if nums[0] == nums[1]:
      return nums[0]

   lower = nums[0]
   upper = nums[-1]
   interval = (upper - lower) // len(nums)

   pointer = len(nums) // 2

   left = 0
   right = len(nums) - 1

   while left != right:
      if nums[pointer] != nums[0] + interval * pointer:
         if nums[pointer - 1] == nums[0] + interval * (pointer -1):
            return nums[0] + interval * pointer
         else:
            right = pointer
            pointer = (left + right) // 2
      else:
         if right - left == 1:
            pointer = right
         else:
            left = pointer
            pointer = (left + right) // 2

nums = [5, 7, 11, 13]
print(solve(nums))

ইনপুট

[5, 7, 11, 13]

আউটপুট

9

  1. পাইথনে লুক অ্যান্ড সে সিকোয়েন্সে nম টার্ম খুঁজে বের করার প্রোগ্রাম

  2. পাইথনে সংখ্যার তালিকা থেকে পাটিগণিতের অনুগামী সংখ্যা বের করার প্রোগ্রাম?

  3. পাইথনে সংখ্যার তালিকা থেকে গাণিতিক ক্রম সংখ্যা খুঁজে বের করার প্রোগ্রাম?

  4. একটি তালিকা থেকে N বৃহত্তম উপাদান খুঁজে পেতে পাইথন প্রোগ্রাম