কম্পিউটার

পাইথনে দুটি স্ট্রিংয়ের বৃহত্তম মার্জ


ধরা যাক আমাদের দুটি স্ট্রিং 'a' এবং 'b' এবং একটি স্ট্রিং 'মার্জ' আছে। কাজটি হল 'a' এবং 'b'-এর অক্ষর দিয়ে স্ট্রিং 'merge' পূরণ করা যাতে,

  • যদি স্ট্রিং 'a' খালি না হয়, তাহলে স্ট্রিং 'a' থেকে প্রথম অক্ষরটি সরিয়ে স্ট্রিং 'মার্জ'-এ কপি করুন।
  • যদি স্ট্রিং 'b' খালি না হয়, তাহলে 'b' স্ট্রিং থেকে প্রথম অক্ষরটি সরিয়ে 'মার্জ' স্ট্রিং-এ কপি করুন।
  • যদি স্ট্রিং 'a' এবং 'b' খালি না হয়, তাহলে স্ট্রিং 'a' থেকে প্রথম অক্ষরগুলি সরিয়ে ফেলুন এবং স্ট্রিং 'মার্জ'-এ অনুলিপি করুন এবং তারপর 'b' স্ট্রিং থেকে প্রথম অক্ষর (যদি থাকে) সরিয়ে দিন ' এবং এটিকে 'মার্জ' স্ট্রিং-এ কপি করুন।
  • উভয় স্ট্রিং থেকে অক্ষরগুলিকে অভিধানিকভাবে সরান, যার মানে, যদি স্ট্রিং 'a' স্ট্রিং 'b' থেকে বড় হয়, তাহলে স্ট্রিং 'a' থেকে অক্ষরটি সরিয়ে তারপর স্ট্রিং 'b'।
  • 'মার্জ' স্ট্রিংটি ফেরত দিন।

উদাহরণস্বরূপ

ইনপুট-1:

a = “bacaa”

b = “abcaa”

আউটপুট:

babcacaaaa

ব্যাখ্যা:

যেহেতু প্রদত্ত স্ট্রিং 'a' স্ট্রিং 'b' থেকে অভিধানগতভাবে বড়, তাই আমরা স্ট্রিং 'a' থেকে প্রথম অক্ষরটি বের করব, অর্থাৎ, "b" এবং তারপর স্ট্রিং 'b' থেকে। এক্সট্র্যাক্ট করার পরে, স্ট্রিংটি হবে "babcacaaaa"৷

এই সমস্যা সমাধানের পদ্ধতি

এই সমস্যাটি সমাধানের জন্য পুনরাবৃত্তিমূলক পদ্ধতি হল যে আমরা স্ট্রিং 'a' এবং স্ট্রিং 'b' এর প্রতিটি অক্ষর বের করব এবং পরীক্ষা করব যে স্ট্রিং 'a'-এর অক্ষরগুলি অন্য স্ট্রিং থেকে অভিধানগতভাবে বড় এবং অবশেষে স্ট্রিং 'মার্জ'-এর সাথে সংযুক্ত হবে। .

আমরা প্রতিটি অক্ষরের সাবস্ট্রিংকে বেশ কয়েকটি অবস্থানের পরে খুঁজে পাব এবং 'মার্জ'-এ সংযুক্ত করব যদি এটি অন্য স্ট্রিং থেকে অভিধানগতভাবে বড় হয়।

  • দুটি ইনপুট স্ট্রিং 'a' এবং 'b' নিন।
  • একটি পুনরাবৃত্ত স্ট্রিং ফাংশন concatenateLargest(string a, string b) ইনপুট হিসাবে দুটি স্ট্রিং নেয় এবং কনক্যাটেনেশনের পরে সবচেয়ে বড় স্ট্রিং প্রদান করে, যেমন, (স্ট্রিং 'a' + স্ট্রিং 'b')।
  • যদি 'a> b' হয়, তাহলে স্ট্রিং 'a' কে পজিশন '0' দিয়ে বিভক্ত করুন এবং স্ট্রিং 'a' থেকে আউটপুট ফেরত দিন।
  • যদি 'a
  • সংযুক্ত স্ট্রিংটি ফেরত দিন।

উদাহরণ

def concatenateLargest(a, b):
   ans = ""
   while a and b:
      if a > b:
         ans = a[0]
         a = a[1:]
      else:
         ans = b[0]
         b = b[1:]
   ans = a
   ans = b
   return ans
a = "bacaa"
b = "abcaa"
print(concatenateLargest(a, b))

উপরের কোডটি চালানোর ফলে আউটপুট তৈরি হবে,

আউটপুট

bacabcaaaa

দুটি স্ট্রিং "bacaa" এবং "abcaa" প্রদত্ত সমস্যা অনুসারে একত্রিত হওয়ার পরে "bacabcaaaa" হয়ে যাবে৷


  1. পাইথন প্রোগ্রাম দুটি অভিধানকে একত্রিত করতে

  2. বর্ণানুক্রমিকভাবে দুটি স্ট্রিংয়ের সাধারণ অক্ষর মুদ্রণের জন্য পাইথন কোড

  3. কিভাবে আমরা দুটি পাইথন অভিধান একত্রিত করতে পারি?

  4. পাইথনে একটি একক স্ট্রিং রূপান্তর করতে দুটি স্ট্রিং কিভাবে যোগদান করবেন?