C++ STL 알고리즘 (Algorithms)

2021. 3. 26. 15:23·SW개발/C++
반응형

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
반응형
저작자표시 (새창열림)

'SW개발 > C++' 카테고리의 다른 글

C++ string  (0) 2021.03.26
따라하며 배우는 C++ 17장  (0) 2021.03.26
C++ STL 반복자 (Iterators)  (0) 2021.03.26
C++ multimap  (0) 2021.03.26
C++ map  (0) 2021.03.26
'SW개발/C++' 카테고리의 다른 글
  • C++ string
  • 따라하며 배우는 C++ 17장
  • C++ STL 반복자 (Iterators)
  • C++ multimap
Caniro
Caniro
  • Caniro
    Minimalism
    Caniro
  • 전체
    오늘
    어제
    • 전체보기 (319)
      • SW개발 (268)
        • Java Spring (6)
        • C++ (186)
        • Python (21)
        • Linux (16)
        • 알고리즘 (13)
        • Git (4)
        • Embedded (1)
        • Raspberrypi (9)
        • React (3)
        • Web (2)
        • Windows Device Driver (6)
      • IT(개발아님) (46)
        • Windows (26)
        • MacOS (7)
        • Utility (11)
      • 챗봇 짬통 (0)
      • 일상 (2)
  • 블로그 메뉴

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

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

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

티스토리툴바