কম্পিউটার

BFS C++ এ প্রতিযোগিতামূলক কোডিংয়ের জন্য STL ব্যবহার করছে?


ব্রেডথ ফার্স্ট সার্চ (BFS) ট্রাভার্সাল হল একটি অ্যালগরিদম, যা একটি প্রদত্ত গ্রাফের সমস্ত নোড দেখার জন্য ব্যবহৃত হয়। এই ট্রাভার্সাল অ্যালগরিদমে একটি নোড নির্বাচন করা হয় এবং তারপরে পার্শ্ববর্তী সমস্ত নোডগুলি একে একে পরিদর্শন করা হয়। সমস্ত সংলগ্ন শীর্ষবিন্দুগুলি সম্পূর্ণ করার পরে, এটি অন্য শীর্ষবিন্দুগুলি পরীক্ষা করার জন্য আরও এগিয়ে যায় এবং এর সন্নিহিত শীর্ষগুলি আবার পরীক্ষা করে৷

BFS C++ এ প্রতিযোগিতামূলক কোডিংয়ের জন্য STL ব্যবহার করছে?

প্রতিযোগিতামূলক কোডিং-এ, আমাদের খুব দ্রুত সমস্যা সমাধান করতে হবে। এই অ্যালগরিদম বাস্তবায়নের জন্য আমরা STL (C++ এর স্ট্যান্ডার্ড লাইব্রেরি) ব্যবহার করব, আমাদের কিউ ডেটা স্ট্রাকচার ব্যবহার করতে হবে। সমস্ত সংলগ্ন শীর্ষবিন্দুগুলি সারিতে যোগ করা হয়, যখন সমস্ত সন্নিহিত শীর্ষবিন্দু সম্পূর্ণ হয়ে যায়, তখন একটি আইটেম সারি থেকে সরানো হয় এবং আবার সেই শীর্ষবিন্দুর মধ্য দিয়ে যেতে শুরু করে৷

গ্রাফে কখনও কখনও, আমরা কিছু চক্র পেতে পারি, তাই আমরা একটি অ্যারে ব্যবহার করব যখন একটি নোড ইতিমধ্যেই পরিদর্শন করা হয়েছে বা না হয়েছে তা চিহ্নিত করতে৷

ইনপুট :গ্রাফের অ্যাডজাসেন্সি ম্যাট্রিক্স।A B C D E FA 0 1 1 1 0 0B 1 0 0 1 1 0C 1 0 0 1 0 1D 1 1 1 0 1 1E 0 1 0 1 0 1F 0 01O পুট :BFS ট্রাভার্সাল:B A D E C F

অ্যালগরিদম

bfs(শীর্ষ, শুরু)

ইনপুট − শীর্ষবিন্দুর তালিকা, এবং শুরু শীর্ষবিন্দু৷

আউটপুট − সমস্ত নোড অতিক্রম করুন, যদি গ্রাফটি সংযুক্ত থাকে।

শুরু করুন একটি খালি সারি que সংজ্ঞায়িত করুন প্রথমে সমস্ত নোডের স্ট্যাটাসকে আনভিজিটেড হিসাবে চিহ্নিত করুন que এ স্টার্টের শীর্ষবিন্দু যোগ করুন যখন que খালি না থাকে, que থেকে আইটেম মুছে ফেলুন এবং u-এর সাথে সংলগ্ন 1 শীর্ষবিন্দুর জন্য শীর্ষবিন্দু u প্রদর্শন করুন , যদি শীর্ষবিন্দুগুলি [i] দেখা না হয়, তাহলে শীর্ষবিন্দুগুলি[i] অস্থায়ীভাবে পরিদর্শন করা হিসাবে চিহ্নিত করুন 

উদাহরণ

#include#include#define NODE 6 useing namespace std;class node { public:int val; int state; //status};int গ্রাফ[NODE][NODE] ={ {0, 1, 1, 1, 0, 0}, {1, 0, 0, 1, 1, 0}, {1, 0, 0, 1, 0, 1}, {1, 1, 1, 0, 1, 1}, {0, 1, 0, 1, 0, 1}, {0, 0, 1, 1, 1, 0}}; void bfs (নোড *ভার্ট, নোড এস) { নোড ইউ; int i, j; সারি<নোড> que; for(i =0; i 

আউটপুট

BFS ট্রাভার্সাল:B A D E C F

  1. একটি অ্যারে প্যালিনড্রোম কিনা বা C++ এ STL ব্যবহার করছে না তা পরীক্ষা করার জন্য প্রোগ্রাম

  2. C++ STL(3.5) এ স্ট্যাক

  3. C++ এ সংযোগ বিচ্ছিন্ন গ্রাফের জন্য BFS

  4. প্রতিযোগিতামূলক কোডিংয়ের জন্য পাইথন কৌশল