মডিউল ১৭_২ঃ ফ্যাক্টোরিয়াল নাম্বার
আমরা এখন ফ্যাক্টোরিয়াল নাম্বার সম্পর্কে জানবো। এটি কি,কিভাবে কাজ করে,ডিপি ইউজ করা উচিত কি না এইসব এর ধারনা নিব।
তাহলে এখন আগে জেনে নেই ফ্যাক্টোরিয়াল কি?
ফ্যাক্টোরিয়ালকে আমরা ! এইটা দিয়ে প্রকাশ করি। এটির মানে হচ্ছে যেই সংখ্যা দেওয়া থাকবে তা থেকে শুরু করে তার আগের সকল পজিটিভ সংখ্যার গুণফল।
৫! = ৫*৪*৩*২*১ = ১২০
৪! = ৪*৩*২*১ = ২৪
তাহলে আমরা বলতে পারি,
n! = n*(n-1)*..........*3*2*1
এখন একটা মজার জিনিস খেয়াল করে দেখি।
৫! = ৫*৪*৩*২*১
আবার ৪! = ৪*৩*২*১
তাহলে বলা যায় না ৫! = ৫*৪!
সেই সাথে তাহলে বলতে পারি n! = n*(n-1)!
তাহলে খেয়াল করে দেখো এখানে একটা রিকারশিব এপ্রোচ এর সন্ধান আমরা পেয়ে যাচ্ছি। কেননা এক প্রবলেম এর কিছু সাব প্রবলেম বিদ্যমান। আমরা বেইস কেইস সেট করে দিব। অর্থাৎ বলবো যে n এর মান ০ হলে ১ দাও। কেননা ০!=১। আর বাকি কাজটা করবো ফাংশনের মাধ্যমে।
রিকারশানতো দেখলাম এবার দেখি memoization করা যায় কিনা। খেয়াল করে দেখো এখানে কোনো রিপিটেড ফাংশন কল নেই। তাই এখানে আসলে অপ্টিমাইজ করার কোনো জায়গা নাই। তাহলে এই থেকে আমরা বুঝতে পারলাম যে সব রিকারশানে আসলে memoization করা যায় না। যেখানে অপ্টিমাইজ করা পসিবল শুধু সেখানে memoization করা যাবে। এই ক্ষেত্রে এই ফাংশনের টাইম কমপ্লেক্সিটি O(N)| কেননা এখানে N সংখ্যক বার ফাংশন কল হচ্ছে।
Last updated