C++ STL 알고리즘 (Algorithms)

2021. 3. 26. 15:23·C++/Library

STL 알고리즘 (Algorithms)

예제

  • 클래스를 원소로 넣을 경우 대부분 비교 연산자 오버로딩을 해놔야 한다.

    #include <iostream>
    #include <vector>
    #include <algorithm>
    
    int            main()
    {
      using namespace std;
    
      vector<int> container;
      for (int i = 0; i < 10; ++i)
        container.push_back(i);
    
      auto itr = min_element(container.begin(), container.end());
      cout << "Min element : " << *itr << endl;
    
      itr = max_element(container.begin(), container.end());
      cout << "Max element : " << *itr << "\n\n";
    
      itr = find(container.begin(), container.end(), 3);
      container.insert(itr, 128);
    
      for (auto& e : container) cout << e << ' ';
      cout << endl;
    
      sort(container.begin(), container.end());
      for (auto& e : container) cout << e << ' ';
      cout << endl;
    
      reverse(container.begin(), container.end());
      for (auto& e : container) cout << e << ' ';
      cout << endl;
    }
    
    /* stdout stderr
    Min element : 0
    Max element : 9
    
    0 1 2 128 3 4 5 6 7 8 9
    0 1 2 3 4 5 6 7 8 9 128
    128 9 8 7 6 5 4 3 2 1 0
    */

  • list의 경우 sort() 함수를 쓸 수 없고, 클래스 멤버 함수인 list::sort()를 사용해야 한다.

    #include <iostream>
    #include <list>
    #include <algorithm>
    
    int            main()
    {
      using namespace std;
    
      list<int> container;
      for (int i = 0; i < 10; ++i)
        container.push_back(i);
    
      auto itr = min_element(container.begin(), container.end());
      cout << "Min element : " << *itr << endl;
    
      itr = max_element(container.begin(), container.end());
      cout << "Max element : " << *itr << "\n\n";
    
      itr = find(container.begin(), container.end(), 3);
      container.insert(itr, 128);
    
      for (auto& e : container) cout << e << ' ';
      cout << endl;
    
      container.sort();
      for (auto& e : container) cout << e << ' ';
      cout << endl;
    
      container.reverse();
      for (auto& e : container) cout << e << ' ';
      cout << endl;
    }
    
    /* stdout stderr
    Min element : 0
    Max element : 9
    
    0 1 2 128 3 4 5 6 7 8 9
    0 1 2 3 4 5 6 7 8 9 128
    128 9 8 7 6 5 4 3 2 1 0
    */

참고

  • https://en.cppreference.com/w/cpp/header/algorithm
저작자표시 (새창열림)

'C++ > Library' 카테고리의 다른 글

C++ sstream  (0) 2021.03.26
C++ string  (0) 2021.03.26
C++ STL 반복자 (Iterators)  (0) 2021.03.26
C++ multimap  (0) 2021.03.26
C++ map  (0) 2021.03.26
'C++/Library' 카테고리의 다른 글
  • C++ sstream
  • C++ string
  • C++ STL 반복자 (Iterators)
  • C++ multimap
Caniro
Caniro
  • Caniro
    Minimalism
    Caniro
  • 전체
    오늘
    어제
    • 분류 전체보기 (317)
      • Algorithm (13)
        • 알기 쉬운 알고리즘 (10)
        • Search (1)
        • Sort (2)
      • Arduino (0)
      • C++ (185)
        • Class (46)
        • Exception (6)
        • Library (51)
        • Overloading (10)
        • SmartPointer (5)
        • Syntax (33)
        • TBC++ (23)
        • Templates (9)
        • VisualStudio (2)
      • Embedded (1)
      • Git (4)
      • Java (5)
      • Linux (16)
        • Error (1)
        • Linux Structure (11)
      • MacOS (7)
      • OS (1)
        • Concurrency (1)
      • Python (21)
        • Class (1)
        • Function (2)
        • Syntax (17)
      • Raspberrypi (9)
      • Review (1)
      • Utility (12)
        • VSCode (5)
        • VirtualBox (3)
      • Web (8)
        • Nginx (1)
        • React (3)
        • Django (1)
      • Windows (20)
        • Registry (3)
        • WSL (1)
        • DeviceDriver (6)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    시스템 복구
    KakaoTalk
    스프링
    citrix workspace
    제외
    SFC
    spring
    vscode
    dism
    Solaris 10
    unix
    백기선
    로지텍 마우스 제스처
    Workspace
    윈도우 명령어
    그림판
    알림
    SunOS 5.1
    Windows 11
    logi options
    MacOS
    윈도우
    스프링 프레임워크 핵심 기술
    EXCLUDE
    mspaint
    맥북 카카오톡 알림 안뜸
    windows
    java
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
Caniro
C++ STL 알고리즘 (Algorithms)
상단으로

티스토리툴바