আসসালামু আলাইকুম! চলে আসলাম আবারো এই সিরিজের দ্বিতীয় পর্ব নিয়ে। গত পর্ব যদি পড়ে না থাকো,তাহলে এই পর্ব শুরুর আগে অবশ্যই সেটা একবার দেখে আসা উচিত। গত পর্বের লিংক এখানে।
আচ্ছা,গত পর্বের শেষে যেমন কথা দিয়েছিলাম , সে অনুযায়ীই আজকের পর্বটা সাজানো হয়েছে। আমরা গত পর্বে দেখেছি কেবলমাত্র একটা গ্রিডে ডানে বামে নড়াচড়া করতে পারলে একটা পয়েন্ট থেকে আরেকটা পয়েন্টে কয়ভাবে যাওয়া যায়।আচ্ছা, ডানে বামের পাশাপাশি আমাদের যদি কর্ণ বরাবর যাতায়াত করার অনুমতি দেয়া হয়,তাহলে একটা পয়েন্ট থেকে আরেকটা পয়েন্টে কয়ভাবে যাওয়া যাবে,সেটা বের করতে চাইলে তোমরা কিভাবে করবে? এটার ক্ষেত্রে গণিতের কম্বিনেশনের সাহায্য নেয়া যেতে পারে,তবে তা অপেক্ষাকৃত জটিল রূপ ধারণ করতে থাকবে। মনে আছে গত পর্বের পদ্ধতি-২ এর কথা,যেখানে আমরা ডাইনামিক প্রোগ্রামিং এর সহায়তায় সমস্যাটি সমাধান করেছিলাম? আমরা আজ এই সমস্যাটিকেও একইভাবে সমাধান করবো! 😀
গত পর্বের Key Lines:
”
দেখো তো,তুমি যদি জানো যে (a,b-1) পয়েন্টে কত ভাবে আসা যায় এবং (a-1,b) পয়েন্টে কতভাবে আসা যায়,তাহলে কি তুমি বলতে পারবে না (a,b) পয়েন্টে কতভাবে আসা যায়? এটা সহজ,ওই দুইপয়েন্টে যতভাবে আসা যায়,তার যোগফলটাই হবে উত্তর! কারণ তুমি কেবলমাত্র এই দুই পয়েন্ট থেকেই (a,b) পয়েন্টে আসতে পারবে,অন্য কোনো উপায়ে পারবে না।
তাহলে আমরা যদি একটা রিকারসিভ ফাংশন লিখি এইভাবে , তাহলে আমরা যেকোনো পয়েন্ট (a,b) তে কতভাবে আসা যায় সেটি পেয়ে যাবঃ
”
আচ্ছা,এখানে থামি। আগের বার শর্ত ছিলো দুইটা,ডানে এবং বামে। এবার শর্ত হচ্ছে তিনটা। ডানে,বামে এবং কর্ণ বরাবর! তাহলে এবার বলো,একটা পয়েন্ট (a,b) তে তুমি কয়টা আলাদা আলাদা জায়গা থেকে আসতে পারো? তোমার উত্তর যদি হয় তিন,তাহলে তুমি সঠিক!
হ্যা,আমরা (a,b) পয়েন্টে (a-1,b-1) এই পয়েন্ট থেকেও এখন চাইলে আসতে পারবো! তাহলে আমাদের রিকারসিভ ফাংশনটা দেখতে যেমন হবেঃ
আর এর কোডটা আগের মতোই হবে,শুধু ফাংশনটাকে একটু পালটে দিতে হবে,এই আর কিঃ
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
#include <stdio.h> #include <string.h> long long dp[21][21]; long long solve(long long m,long long n) { if(m==0 || n==0) return 1; if(dp[m][n]!=-1) return dp[m][n]; // agei jodi calculate kore thaki,tahole notun kore ar calculate korbona. Return kore dibo. else { dp[m][n] = solve(m-1,n)+ solve(m,n-1)+solve(m-1,n-1); return dp[m][n]; } } int main() { memset(dp,-1,sizeof(dp)); // puro dp array ta ke -1 diye initialize kore dilam. long long m,n; scanf("%lld%lld",&m,&n); printf("%lld\n",solve(m,n)); return 0; } |
এবার আলোচনা করা যাক আরেক ধরণের সমস্যা নিয়ে। না না,একেবারে নতুন কোনো সমস্যা না,এটারই মোডিফাইড ভার্সন। মনে আছে ডিপজলের কথা? এবার আমাদের গ্রিডে ডিপজল চলে আসবে! আমাদের গ্রিডের সেই পয়েন্ট গুলোকে এভয়েড করে সামনে এগিয়ে আমাদের লক্ষ্যস্থানে পৌঁছুতে হবে! কি,পারবেনা?
এটাকে আমরা দুইভাবেই ব্যাখ্যা করবো। প্রথমে দেখাবো স্মার্ট আর শক্তিশালী ভার্সন ডাইনামিক প্রোগ্রামিং এর সাহায্যে কিভাবে এটা সমাধান করা যায়। পরের পর্বে কম্বিনেশনের পদ্ধতিটা আলোচনা করবো,কারণ ওটা অপেক্ষাকৃত জটিল! তাহলে চলো শুরু করা যাকঃ
পদ্ধতিঃ (ডাইনামিক প্রোগ্রামিং)
ধরো,তুমি (5,5) এর একটা গ্রিডের (0,0) পয়েন্টে আছো। তোমাকে (5,5) পয়েন্টে যেতে হবে। কিন্তু তুমি (2,2) পয়েন্টটা ব্যবহার করতে পারবে না,কারণ ওখানে ডিপজল আছে। গেলেই তোমাকে মেরে ফেলবে। এবার তুমি কয়ভাবে (5,5) এ যেতে পারবে?
ডাইনামিক প্রোগ্রামিং এর সাহায্যে এটা চোখের পলকেই সল্ভ করে ফেলা যায়! তুমি যেই ফাংশনটা লিখেছিলা,সেখানে শুধুমাত্র একটা শর্ত জুড়ে দাও,যাতে যেতে যেতে (2,2) পয়েন্টে আসলেই সেই পথটাকে গণনার বাইরে পাঠিয়ে দেয়া হয়! অর্থাৎ , যেই পথটা (2,2) পয়েন্ট দিয়ে যাবে,তাকে নিয়ে আমরা কোনো হিসাব করবো না,বাকিগুলো নিয়ে করবো! 😀 কিভাবে করা যায় সেটা? ফাংশনে a,b এর মান (2,2) হলেই return 0 করে দিবে,তাহলেই কাজ শেষ! ঐ পথটা হিসাবের বাইরে চলে যাবে! কোডটা দেখে আসিঃ
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
#include <stdio.h> #include <string.h> long long dp[21][21]; long long solve(long long m,long long n,long long a,long long b) { if(m==0 || n==0) return 1; if(m==a && n==b) return 0; // ekhanei shei Dipjol er path ta avoid kora hocche. if(dp[m][n]!=-1) return dp[m][n]; // agei jodi calculate kore thaki,tahole notun kore ar calculate korbona. Return kore dibo. else { dp[m][n] = solve(m-1,n,a,b)+ solve(m,n-1,a,b); return dp[m][n]; } } int main() { memset(dp,-1,sizeof(dp)); // puro dp array ta ke -1 diye initialize kore dilam. long long m,n,a,b; scanf("%lld%lld%lld%lld",&m,&n,&a,&b); printf("%lld\n",solve(m,n,a,b)); return 0; } |
চমৎকার নয় কি? এভাবে তোমরা মাল্টিপল ডিপজল এর জন্যেও সল্ভ করে ফেলতে পারবে। সেটা কিভাবে ? চিন্তা করো!
আজকের পর্ব এইটুকুই! আগামী পর্বে এই সমস্যাটার কম্বিনেশন ভার্সন এবং brilliant.org এর একটা চমৎকার গ্রিড ট্রাভেলিং এর প্রব্লেম নিয়ে হাজির হবো। সেই পর্যন্ত সবাই ভালো থাকো!
porer ta post koren vai 😀 eidao sesh,,, easy ase :
🙂
ivermectin coupon https://ivermectin.mlsmalta.com/
aurogra drug interactions https://aurogra.buszcentrum.com/
vidalista 40 for sale https://vidalista40mg.mlsmalta.com/
remdesivir or hydroxychloroquine https://hydroxychloroquinee.com/
hydroxychloroquine works against covid https://sale.azhydroxychloroquine.com/
doxycycline 100mg dogs http://doxycycline.zolftgenwell.org/
amoxicillin samples https://amoxycillin1st.com/
tinder login, tinder website
tinder date
viagra & cialis value pack https://cialis.stdstory.com/
does walmart sell generic dapoxetine https://ddapoxetine.com/
hello there and thank you for your info
I have certainly picked up something new from right here.
I did however expertise some technical issues using this
website, as I experienced to reload the website lots of times previous to
I could get it to load correctly. I had been wondering if your web host is OK?
Not that I’m complaining, but slow loading instances times will
often affect your placement in google and could damage
your high quality score if advertising and marketing with Adwords.
Well I’m adding this RSS to my email and can look out for a lot more of your respective interesting content.
Ensure that you update this again very soon. http://antiibioticsland.com/Augmentin.htm
I simply could not leave your site prior to suggesting that
I extremely enjoyed the usual information a
person provide on your guests? Is going to be again incessantly to
investigate cross-check new posts
tadalafil generic 5mg cialis professional samples cialis from mexico
order hydroxychloroquine 200mg buy plaquenil hydroxychloroquine to buy uk