Trỏ đến vị trí kết thúc không phải

  • No School
  • AA 1
  • 43

This preview shows page 4 - 8 out of 43 pages.

/*trỏ đến vị trí kết thúc (không phải phần tử cuối cùng nhé) của vector) */ it=vector.end(); /* khai báo iterator ngược “rit” */ vector <int> :: reverse_iterator rit; rit = vector.rbegin(); /* trỏ đến vị trí kết thúc của vector theo chiều ngược (không phải phần tử đầu tiên nhé*/ rit = vector.rend(); Tất cả các hàm iterator này đều có độ phức tạp O(1).
Image of page 4
STL for newbies – Điêu Xuân Mạnh – D10CN6 PTIT 5 2. Vector (Mảng động): Khai báo vector: #include <vector> ... /* Vector 1 chiều */ /* tạo vector rỗng kiểu dữ liệu int */ vector <int> first; //tạo vector với 4 phần tử là 100 vector <int> second (4,100); // lấy từ đầu đến cuối vector second vector <int> third (second.begin(),second.end()) //copy từ vector third vector <int> four (third) /*Vector 2 chiều*/ /* Tạo vector 2 chiều rỗng */ vector < vector <int> > v; /* khai báo vector 5×10 */ vector < vector <int> > v (5, 10) ; /* khai báo 5 vector 1 chiều rỗng */ vector < vector <int> > v (5) ; //khai báo vector 5*10 với các phần tử khởi tạo giá trị là 1 vector < vector <int> > v (5, vector <int> (10,1) ) ; Các bạn chú ý 2 dấu “ngoặc” không được viết liền nhau. Ví dụ như sau là sai : /*Khai báo vector 2 chiều SAI*/ vector <vector <int>> v; Các hàm thành viên: Capacity: - size : trả về số lượng phần tử của vector. ĐPT O(1). - empty : trả về true(1) nếu vector rỗng, ngược lại là false(0). ĐPT O(1). Truy cập tới phần tử : - operator [] : trả về giá trị phần tử thứ []. ĐPT O(1). - at : tương tự như trên. ĐPT O(1). - front: trả về giá trị phần tử đầu tiên. ĐPT O(1). - back: trả về giá trị phần tử cuối cùng. ĐPT O(1). Chỉnh sửa:
Image of page 5
STL for newbies – Điêu Xuân Mạnh – D10CN6 PTIT 6 - push_back : thêm vào ở cuối vector. ĐPT O(1). - pop_back : loại bỏ phần tử ở cuối vector. ĐPT O(1). - insert (iterator,x): chèn “x” vào trước vị trí “iterator” ( x có thể là phần tử hay iterator của 1 đoạn phần tử…). ĐPT O(n). - erase : xóa phần tử ở vị trí iterator. ĐPT O(n). - swap : đổi 2 vector cho nhau (ví dụ: first.swap(second);). ĐPT O(1). - clear: xóa vector. ĐPT O(n). Nhận xét: - Sử dụng vector sẽ tốt khi: o Truy cập đến phần tử riêng lẻ thông qua vị trí của nó O(1) o Chèn hay xóa ở vị trí cuối cùng O(1). - Vector làm việc giống như một “mảng động”. Ví dụ 1: Ví dụ này chủ yếu để làm quen sử dụng các hàm chứ không có đề bài cụ thể. #include <iostream> #include <vector> using namespace std; vector <int> v; //Khai báo vector vector <int>::iterator it; //Khai báo iterator vector <int>::reverse_iterator rit; //Khai báo iterator ngược int i; main() { for (i=1;i<=5;i++) v.push_back(i); // v={1,2,3,4,5} cout << v.front() << endl; // In ra 1 cout << v.back() << endl; // In ra 5 cout << v.size() << endl; // In ra 5 v.push_back(9); // v={1,2,3,4,5,9} cout << v.size() << endl; // In ra 6 v.clear(); // v={} cout << v.empty() << endl; // In ra 1 (vector rỗng) for (i=1;i<=5;i++) v.push_back(i); // v={1,2,3,4,5} v.pop_back(); // v={1,2,3,4} cout << v.size() << endl; // In ra 4 v.erase(v.begin()+1); // Xóa ptử thứ 1 v={1,3,4} v.erase(v.begin(),v.begin()+2); // v={4} v.insert(v.begin(),100); // v={100,4} v.insert(v.end(),5); // v={100,4,5} /*Duyệt theo chỉ số phần tử*/ for (i=0;i<v.size();i++) cout << v[i] << " "; // 100 4 5 cout << endl; /*Chú ý: Không nên viết
Image of page 6
STL for newbies – Điêu Xuân Mạnh – D10CN6 PTIT 7 for (i=0;i<=v.size()-1;i++) ...
Image of page 7
Image of page 8

You've reached the end of your free preview.

Want to read all 43 pages?

  • Fall '19

What students are saying

  • Left Quote Icon

    As a current student on this bumpy collegiate pathway, I stumbled upon Course Hero, where I can find study resources for nearly all my courses, get online help from tutors 24/7, and even share my old projects, papers, and lecture notes with other students.

    Student Picture

    Kiran Temple University Fox School of Business ‘17, Course Hero Intern

  • Left Quote Icon

    I cannot even describe how much Course Hero helped me this summer. It’s truly become something I can always rely on and help me. In the end, I was not only able to survive summer classes, but I was able to thrive thanks to Course Hero.

    Student Picture

    Dana University of Pennsylvania ‘17, Course Hero Intern

  • Left Quote Icon

    The ability to access any university’s resources through Course Hero proved invaluable in my case. I was behind on Tulane coursework and actually used UCLA’s materials to help me move forward and get everything together on time.

    Student Picture

    Jill Tulane University ‘16, Course Hero Intern

Stuck? We have tutors online 24/7 who can help you get unstuck.
A+ icon
Ask Expert Tutors You can ask You can ask You can ask (will expire )
Answers in as fast as 15 minutes
A+ icon
Ask Expert Tutors