[백준] 10814번: 나이순 정렬 C++로 풀어보기

2023. 8. 6. 16:46·Algorithm/Baekjoon(C++)

10814번 설명

생각

구조체를 사용해서 풀면 될 것 같다.

 

문제를 풀 때 시행착오를 겪었는데,

 

처음에는 struct s s1[100005]로 구조체 배열을 선언했었는데, 그러면 코드가 잘 실행되지 않는다.

-> 스택 오버플로우가 발생하기 때문! 구조체 배열을 동적 할당하자.

 

그리고 정렬을 할 때 그냥 sort를 썼었는데, 그냥 sort를 쓰면 동일한 우선순위를 가진 원소들 사이의 상대적인 순서가 보존되지 않는다. 

-> sort가 아닌 stable_sort를 써야한다.

 

코드
#include <bits/stdc++.h>
using namespace std;

struct s { // 구조체 선언
    int age;
    string name;
};

bool compare(const s& s1, const s& s2) { // 나이가 적은 순서대로 정렬
    return s1.age < s2.age;
}

int main(void) {
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    
    int n;
    cin >> n;

    struct s* st = new struct s[n]; // 동적으로 구조체 배열 할당
    // 동적으로 할당한 배열은 스택이 아닌 힙 메모리를 사용하므로
    // 스택의 크기 제한을 초과할 걱정이 없어도 된다.
 

    for (int i = 0; i < n; i++) { // 나이와 이름 입력
        cin >> st[i].age;
        cin >> st[i].name;
    }

    // stable_sort를 사용해야 동일한 우선순위를 가진 원소들 사이의 상대적인 순서가 보존된다.
    stable_sort(st, st + n, compare);

    for (int i = 0; i < n; i++) { // 출력
        cout << st[i].age << " " << st[i].name << "\n";
    }
    
    delete[] st; //동적 할당 해제
}

 

결과

10814번 결과

사실 구조체를 많이 써본 적이 없었는데 이번 문제를 통해 구조체에 더욱 익숙해질 수 있었다.

그리고 STL sort는 비교 함수를 내가 정해서 넘겨줄 수 있다는 것을 기억하자!

저작자표시 비영리 변경금지 (새창열림)

'Algorithm > Baekjoon(C++)' 카테고리의 다른 글

[백준] 1931번: 회의실 배정 C++로 풀어보기  (0) 2023.08.09
[백준] 1520번: 내리막 길 C++로 풀어보기  (0) 2023.08.06
[백준] 10989번: 수 정렬하기 3 C++로 풀어보기  (1) 2023.08.05
[백준] 15665번: N과 M (11) C++로 풀어보기  (0) 2023.07.31
[백준] 2630번: 색종이 만들기 C++로 풀어보기  (0) 2023.07.30
'Algorithm/Baekjoon(C++)' 카테고리의 다른 글
  • [백준] 1931번: 회의실 배정 C++로 풀어보기
  • [백준] 1520번: 내리막 길 C++로 풀어보기
  • [백준] 10989번: 수 정렬하기 3 C++로 풀어보기
  • [백준] 15665번: N과 M (11) C++로 풀어보기
퀵차분
퀵차분
Web Developer 🥐
QC's DevlogWeb Developer 🥐
  • 퀵차분
    QC's Devlog
    퀵차분
  • 전체
    오늘
    어제
    • 분류 전체보기 (168)
      • Frontend (28)
        • HTML, CSS (7)
        • Javascript (3)
        • React (11)
        • Typescript (2)
        • Next.js (4)
      • Node.js (3)
      • Fedify (3)
      • Study (40)
        • Modern JS Deep Dive (13)
        • SQL (1)
        • Network (1)
        • 프롬프트 엔지니어링 (4)
        • 인공지능 (9)
        • 시스템프로그래밍 (11)
        • 선형대수학 (1)
      • Intern (4)
      • KUIT (20)
      • Algorithm (48)
        • Baekjoon(C++) (26)
        • Programmers(JavaScript) (22)
      • 우아한테크코스(프리코스) (4)
      • Project (7)
        • PROlog (4)
        • Nomadcoder (2)
      • 생각 (4)
      • Event (7)
  • 블로그 메뉴

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

  • 공지사항

  • 인기 글

  • 태그

    프로그래머스
    음악추천
    HTML
    백준
    프론트엔드
    리액트
    KUIT
    프로그래머스 자바스크립트
    react
    next.js
    알고리즘
    javascript
    typescript
    자바스크립트
    티스토리챌린지
    오블완
    타입스크립트
    프롬프트 엔지니어링
    인공지능
    시스템프로그래밍
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
퀵차분
[백준] 10814번: 나이순 정렬 C++로 풀어보기

개인정보

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

티스토리툴바

단축키

내 블로그

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

블로그 게시글

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

모든 영역

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

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