Reading Time: 2 minutes

যারা প্রোগ্রামিং প্রবলেম সমাধান করেন তাদের কাছে খুবই পরিচিত একটি সাইট Uva Online Judge . এই  সাইটটির সবচাইতে বড় সুবিধা, এটিতে প্রচুর সুন্দর সুন্দর প্রবলেম দেয়া আছে । আর জ্যামিতিক প্রবলেম এর জন্য ব্যাপকতায় এই সাইটটির কোন জুড়ি নেই , অসংখ্য প্রবলেম সেখানে দেয়া আছে!

আজকে আমরা আমাদের লেখার পর্বটি সাজিয়েছি  UVa- 10112 (Mycam  Triangles) দিয়ে । আমরা এখন এই সুন্দর Geometric Problem টি কিভাবে সমাধান করব তা নিয়ে কিছু কথা বলব ।

Problem Link :  https://uva.onlinejudge.org/index.php?option=onlinejudge&page=show_problem&problem=1053

প্রবলেমটি তে মূলত বলা হয়েছে ,  এখানে কিছু পয়েন্ট দেয়া থাকবে [ সর্বনিম্ন ৪ এবং সর্বোচ্চ ১৫ টি ]  আর দেয়া হবে তাদের পরিচয় দানকারী কিছু  ইংরেজি বর্ণ । আমাদের কাজ হবে এখান থেকে এমন একটি ত্রিভুজ বের করা যার ক্ষেত্রফল সর্বোচ্চ আর সেটির মাঝে প্রদত্ত বিন্দুগুলোর আর কোনটিকে পাওয়া যাবে না । পরে যেই পয়েণ্ট গুলো দিয়ে সেই ত্রিভুজটি পাওয়া যাবে তার পরিচয় কারী ইংরেজি বর্ণগুলোকে অ্যালফাবেটিক অর্ডারে ছোট থেকে বড় তে প্রিণ্ট করা ।

Algorithm :

১. প্রথমেই আমরা একটি স্ট্রাকচার অ্যারে নিব । এখানে প্রদত্ত প্রত্যেক ইনপুটের জন্য অ্যারেতে প্রদত্ত ইংরেজি বর্ণটি আর তার পয়েণ্ট গুলোকে সেভ করে রাখব ।

২. তারপর আমরা সেটাকে অ্যালফাবেটিক অর্ডারে ছোট থেকে বড় তে সর্ট করব । এতে আমাদের রেজাল্ট প্রিন্ট করতে সুবিধা হবে ।

৩. এখন আমরা একটি O(n^3) লুপ চালাব প্রত্যেক কম্বিনিশন এ ত্রিভুজ বের করার জন্য । তারপর সাথে সাথেই আমরা চেক করব যে এই প্রাপ্ত ত্রিভুজটির মধ্যে আমাদের  আর কোন বিন্দু আছে কিনা যেটা ইনপুটে দেয়া । যদি আমরা দেখি যে অন্য কোন বিন্দু এর মধ্যে আছে তাহলে এই ত্রিভুজ নেয়া  যাবে না । অন্যথায় নেয়া যাবে । এভাবে আমরা সবচাইতে বড় ক্ষেত্রফল এর ত্রিভুজটি নিব । আর এটিই হবে আমাদের কাঙ্ক্ষিত আউটপুট ।

Equations :

area = 0.5 * [ x1 * (y2 – y3) + x2 * (y3 – y1) + x3 * (y1 – y2) ]

2 * area =  [ x1 * (y2 – y3) + x2 * (y3 – y1) + x3 * (y1 – y2) ]

আমরা ইন্টিজার দিয়ে কাজ করব । কারণ আমাদের তো আর এরিয়া প্রিন্ট করতে হবে না যে তার জন্য আমাদের ফ্র্যাকশন নিয়ে কাজ করতে হবে ।

আর কোন পয়েণ্ট ভেতরে আছে কিনা তার জন্য আমরা সেগমেন্টেড ভাবে ক্ষেত্রফল বের করব আর তার সমষ্টি যদি আমাদের কম্বিনশন ত্রিভুজ এর সমান হয় তাহলে সেই বিন্দুটি আমাদের কম্বিনশন ত্রিভুজ এর মধ্যে আছে অন্যথায় নেই ।

Picture

area = ABD  + ACD + BCD

if(area = আমাদের কম্বিনশন এর ত্রিভুজ এর area)  তাহলে এই ত্রিভুজ নেয়া যাবে না । অন্যথায় এটা আমাদের একটা সম্ভাব্য উত্তর ।

Code :

আমরা আগে নিজে ট্রাই করব , আর যদি নিতান্ত না পারি তাহলে নিচের কোডটি দেখব ।

তো আজকের মত এখানেই বিদায় ।

আমরা  ঈন শা আল্লাহ সামনে আর ও অনেক সুন্দর সুন্দর প্রবলেম নিয়ে আলোচনা করব । ততদিন সবাই ভাল থাক আর বেশি বেশি প্রবলেম সল্ভ করতে থাক ।