যে পুনরাবৃত্তগুলি শেষ এবং শুরু থেকে উভয় দিক থেকে একটি পরিসরের উপাদানগুলির ক্রম অ্যাক্সেস করার বিশেষাধিকার রাখে তারা দ্বিমুখী পুনরাবৃত্তিকারী নামে পরিচিত . পুনরাবৃত্ত তালিকা মানচিত্র এবং সেটের মত ডেটা প্রকারে কাজ করতে পারে।
দ্বিমুখী পুনরাবৃত্তিকারী ফরোয়ার্ডিং ইটারেটর এর মত একই বৈশিষ্ট্য আছে , শুধুমাত্র পার্থক্য যে তারা হ্রাস করা যেতে পারে −
| সম্পত্তি | বৈধ অভিব্যক্তি |
|---|---|
| ডিফল্ট-নির্মাণযোগ্য, অনুলিপি নির্মাণযোগ্য, অনুলিপি-অর্পণযোগ্য এবং ধ্বংসযোগ্য | X a; X b(a); b =a; |
| সমতা/বৈষম্য অপারেটর ব্যবহার করে সমতার জন্য তুলনা করা যেতে পারে (অর্থপূর্ণ যখন উভয় পুনরাবৃত্তিকারী মান একই অন্তর্নিহিত অনুক্রমের উপর পুনরাবৃত্তি করে)। | a ==খ a !=খ |
| *a a->মি | |
| পরিবর্তনযোগ্য পুনরাবৃত্তিকারীদের জন্য (অ-স্থির পুনরাবৃত্তিকারী):একটি lvalue হিসাবে ডিরেফারেন্স করা যেতে পারে (যদি একটি ডিরেফারেন্সযোগ্য অবস্থায় থাকে)। | *a =t |
| বৃদ্ধি করা যেতে পারে (যদি ডিরেফারেন্সযোগ্য অবস্থায় থাকে)। ফলাফল হয় dereferenceable অথবা একটি past-the-end iterator. দুটি পুনরাবৃত্তিকারী যা সমান তুলনা করে, উভয়ের বৃদ্ধি হওয়ার পরে সমান তুলনা করতে থাকে। | ++a a++ *a++ |
| --ক একটি-- *ক-- | |
| Lvalues অদলবদল করা যায়। | swap(a,b) |
যেখানে X হল একটি দ্বিমুখী পুনরাবৃত্তিকারী , a এবং b হল এই ইটারেটর টাইপের অবজেক্ট, এবং t হল ইটারেটর টাইপ দ্বারা নির্দেশিত টাইপের একটি অবজেক্ট (বা অন্য কিছু টাইপ যা lvalue এ বরাদ্দ করা যেতে পারে X টাইপের একটি বস্তুকে ডিরেফারেন্স করে ফেরত দেওয়া হয়।
C++ এ দ্বিমুখী পুনরাবৃত্তির ধারণা।
-
দ্বিমুখী পুনরাবৃত্তিকারীগুলি ফরওয়ার্ডিং ইটারেটরগুলির সমস্ত বৈশিষ্ট্য এবং উপসর্গ এবং পোস্টফিক্স হ্রাস অপারেটরগুলিকে সমর্থন করে৷
-
এই ধরণের পুনরাবৃত্তিকারী উভয় দিকের উপাদানগুলি অ্যাক্সেস করতে পারে, যেমন শেষ এবং শুরুতে।
-
র্যান্ডম অ্যাক্সেস ইটারেটরও এক ধরনের দ্বিমুখী পুনরাবৃত্তিকারী।
-
দ্বিমুখী পুনরাবৃত্তিকারীদের ফরওয়ার্ডিং ইটারেটরের বৈশিষ্ট্য রয়েছে, তবে পার্থক্য হল এই পুনরাবৃত্তিকারীকেও হ্রাস করা যেতে পারে।
Input: 1 2 3 4 5 6 7 8 9 10 Output: 10 9 8 7 6 5 4 3 2 1
উদাহরণ
#include <iostream>
#include<iterator>
#include<vector>
using namespace std;
int main() {
vector<int> vec{1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
vector<int> ::iterator it;
vector<int> :: reverse_iterator rev_it;
for(it = vec.begin(); it != vec.end(); it++)
cout<<*it<<" ";
cout<< endl;
for(rev_it = vec.rbegin(); rev_it!= vec.rend(); rev_it++)
cout<<*rev_it<<" ";
} আউটপুট
1 2 3 4 5 6 7 8 9 10 10 9 8 7 6 5 4 3 2 1