ল্যাটিন বর্গ হল একটি ম্যাট্রিক্স যার একটি বিশেষ প্যাটার্ন রয়েছে। আসুন প্যাটার্ন পরীক্ষা করার জন্য বিভিন্ন উদাহরণ দেখি।
1 22 11 2 33 1 22 3 11 2 3 44 1 2 33 4 1 22 3 4 1
আপনি যে ল্যাটিন বর্গক্ষেত্রটি পাবেন তা বিভিন্ন আকারের হবে যেমন আপনি উপরের উদাহরণগুলিতে লক্ষ্য করেছেন। কিন্তু, আপনি যদি উপরের ম্যাট্রিক্সের প্যাটার্নটি মনোযোগ সহকারে পর্যবেক্ষণ করেন, তাহলে আপনি দেখতে পাবেন যে পূর্ববর্তী সারির শেষ সংখ্যাটি পরবর্তী সারির প্রথম উপাদান হিসেবে আসে।
যে প্যাটার্ন লুকানো ল্যাটিন বর্গক্ষেত্র. আমাদের সেই প্রোগ্রামটি লিখতে হবে যা ইনপুট n এর জন্য উপরের ম্যাট্রিক্স তৈরি করে।
অ্যালগরিদম
- আপনার পছন্দের যেকোনো নম্বর দিয়ে n শুরু করুন।
- n + 1 মান সহ একটি সংখ্যা শুরু করুন এটিকে first_half_end বলুন।
- একটি লুপ লিখুন যা 1 থেকে n উভয়ই অন্তর্ভুক্ত করে পুনরাবৃত্তি করে।
- first_half_start নামক একটি ভেরিয়েবলে first_half_end এর মান বরাদ্দ করুন।
- একটি লুপ লিখুন যতক্ষণ না first_half_start মান n এ পৌঁছায়।
- পুনরাবৃত্ত ভেরিয়েবল প্রিন্ট করুন যেমন, first_half_start.
- একটি লুপ লিখুন যা 1 থেকে প্রথম_হাফ_এন্ড পর্যন্ত পুনরাবৃত্তি করে।
- পুনরাবৃত্ত ভেরিয়েবল প্রিন্ট করুন।
- প্রথম_হাফ_এন্ডের মান 1 দ্বারা হ্রাস করুন।
- পরবর্তী সারিটি সরান।
বাস্তবায়ন
পাইথন
-এ উপরের অ্যালগরিদমের বাস্তবায়ন নিম্নরূপdef generateLatinSquare(n):first_half_end =n + 1 in range (1, n + 1):first_half_start =first_half_end যখন (first_half_start <=n):print(first_half_start, end=" ") first_half_start + পরিসরে দ্বিতীয়_হাফ_স্টার্টের জন্য(1, প্রথম_হাফ_এন্ড):প্রিন্ট(second_half_start, end=" ") first_half_end -=1 print() print() if __name__ =="__main__":generateLatinSquare(2) generateLatinSquare(3) generate(4) এ /প্রে>আউটপুট
আপনি যদি উপরের কোডটি চালান, তাহলে আপনি নিম্নলিখিত ফলাফল পাবেন।
1 22 11 2 33 1 22 3 11 2 3 44 1 2 33 4 1 22 3 4 1