কম্পিউটার

C++ এ প্রদত্ত স্থানাঙ্কের সেট সহ আয়তক্ষেত্রের ন্যূনতম ক্ষেত্রফল খুঁজুন


ধরুন আমাদের XY সমতলে কিছু বিন্দুর অ্যারে আছে। আমাদের আয়তক্ষেত্রের ন্যূনতম ক্ষেত্রফল খুঁজে বের করতে হবে যা এই বিন্দুগুলি থেকে গঠিত হতে পারে। আয়তক্ষেত্রের দিকটি X এবং Y অক্ষের সমান্তরাল হওয়া উচিত। যদি আমরা আয়তক্ষেত্র গঠন করতে না পারি, তাহলে 0 ফেরত দিন। সুতরাং বিন্দুর বিন্যাস যদি হয় [(1, 1), (1, 3), (3, 1), (3, 3), (2, 2)] . আউটপুট 4 হবে। যেহেতু (1, 1), (1, 3), (3, 1) এবং (3, 3) পয়েন্ট ব্যবহার করে আয়তক্ষেত্র তৈরি করা যেতে পারে।

এটি সমাধান করার জন্য, x স্থানাঙ্ক দ্বারা বিন্দুগুলি দিন, যাতে সরল উল্লম্ব রেখার বিন্দুগুলি একসাথে গোষ্ঠীবদ্ধ হয়। তারপর (x, y1) এবং (x, y2) গ্রুপের প্রতিটি বিন্দুর জন্য আমরা এই জোড়া বিন্দুর সাথে ক্ষুদ্রতম আয়তক্ষেত্রটি খুঁজে পাব, আয়তক্ষেত্রের ডানদিকের প্রান্তটি তৈরি করা হবে। আমরা অন্য সব জোড়া পয়েন্টের ট্র্যাক রেখে এটি করতে পারি, আমরা আগে পরিদর্শন করেছি। অবশেষে প্রাপ্ত আয়তক্ষেত্রের ন্যূনতম সম্ভাব্য ক্ষেত্রফল ফেরত দিন।

উদাহরণ

import collections
def findMinArea(Arr):
   columns = collections.defaultdict(list)
   for x, y in Arr:
      columns[x].append(y)
   lastx = {}
   ans = float('inf')
   for x in sorted(columns):
      col = columns[x]
      col.sort()
      for j, y2 in enumerate(col):
         for i in range(j):
            y1 = col[i]
   if (y1, y2) in lastx:
      ans = min(ans, (x - lastx[y1, y2]) * (y2 - y1))
      lastx[y1, y2] = x
   if ans < float('inf'):
      return ans
   else:
      return 0
A = [[1, 1], [1, 3], [3, 1], [3, 3], [2, 2]]
print('Minimum area of rectangle:',findMinArea(A))

আউটপুট

Minimum area of rectangle: 4

  1. C++ এ আয়তক্ষেত্র ক্ষেত্র II

  2. C++ এ আয়তক্ষেত্র এলাকা

  3. C++ এ পয়েন্টের একটি নির্দিষ্ট সেটের জন্য সহজ বন্ধ পথ খুঁজুন

  4. C++ এ মধ্যবিন্দু ব্যবহার করে আয়তক্ষেত্রের কোণগুলি খুঁজুন