Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> C++

จะสำรวจชุด C ++ ในทิศทางย้อนกลับได้อย่างไร


สมมุติว่าเรามีเซต, แล้วเราต้องข้ามเซตไปในทิศกลับกัน. ดังนั้นหากเซตเป็นเช่น S =[10, 15, 26, 30, 35, 40, 48, 87, 98] ผลลัพธ์จะเป็น:98 87 48 40 35 30 26 15 10

หากต้องการย้อนกลับในลำดับที่กลับกัน เราสามารถใช้ reverse_iterator เราจะใช้ฟังก์ชัน rbegin() และ rend() เพื่อเริ่มต้นและสิ้นสุดของตัววนซ้ำแบบย้อนกลับ

ตัวอย่าง

#include <iostream>
#include <set>
using namespace std;
int main() {
   int arr[] = {10, 15, 26, 30, 35, 40, 48, 87, 98};
   set<int> my_set(arr, arr + sizeof(arr) / sizeof(arr[0]));
   set<int>::iterator it;
   cout << "Elements of Set in forward order: ";
   for (it = my_set.begin(); it != my_set.end(); it++)
      cout << *it << " ";
   set<int>::reverse_iterator rev_it;
   cout << "\nElements of Set in reverse order: ";
   for (rev_it = my_set.rbegin(); rev_it != my_set.rend(); rev_it++)
      cout << *rev_it << " ";
}

ผลลัพธ์

Elements of Set in forward order: 10 15 26 30 35 40 48 87 98
Elements of Set in reverse order: 98 87 48 40 35 30 26 15 10