C++ STL 알고리즘 (Algorithms)

2021. 3. 26. 15:23·C++/Library
목차
  1. 예제
  2. 참고

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
  1. 예제
  2. 참고
'C++/Library' 카테고리의 다른 글
  • C++ sstream
  • C++ string
  • C++ STL 반복자 (Iterators)
  • C++ multimap
Caniro
Caniro
MinimalismCaniro 님의 블로그입니다.
  • 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)
  • 블로그 메뉴

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

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

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

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.