[BOJ / C++] 시리얼 번호 (정렬)

2025. 7. 18. 22:07·코딩테스트/BOJ

문제링크: https://www.acmicpc.net/problem/1431

 

1. 코드

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

int main() {
    ios::sync_with_stdio(0); cin.tie(0);

    int n;
    cin >> n;
    
    vector<string> arr(n);
    for (int i = 0; i < n; i++) {
        cin >> arr[i];
    }

    sort(arr.begin(), arr.end(), [](const string& a, const string& b){
        if (a.length() != b.length()) return a.length() < b.length();
        
        int aNum = 0, bNum = 0;
        for (char c: a) {
            if (isdigit(c)) aNum += c - '0';
        }
        for (char c: b) {
            if (isdigit(c)) bNum += c - '0';
        }
        
        if (aNum != bNum) return aNum < bNum;
        else return a < b;
    });

    for (int i = 0; i < n; i++) {
        cout << arr[i] << '\n';
    }
}

 

 

2. 분석

sort의 비교함수를 람다함수로 작성해주면 된다. cctype 헤더에 있는 문자 분류, 문자 변환 함수를 정리하면 다음과 같다.

 

  • std::isalpha(int ch) : 알파벳(A–Z, a–z)이면 참
  • std::isdigit(int ch) : 숫자(0–9)이면 참
  • std::islower(int ch) : 소문자(a–z)이면 참
  • std::isupper(int ch) : 대문자(A–Z)이면 참

 

 

  • std::toupper(int ch) : 소문자를 대응하는 대문자로 변환
  • std::tolower(int ch) : 대문자를 대응하는 소문자로 변환

비교함수를 작성할 때 주의할 사항은 다음과 같다.

 

1. 비교함수는 두 값이 같을 때 (또는 우선순위가 같을 때) false를 반환

// 틀린 방법 (런타임에러 발생가능)
bool cmp(int a, int b) {
	if (a >= b) return true;
    return false;
}

// 올바른 방법
bool cmp(int a, int b) {
	return a > b;   // 값이 같을 때 false를 리턴해야한다!
}

 

 

2. 비교함수의 인자로 객체 전달 시 reference 사용

// & 미사용으로 인한 복사 오버헤드 발생
bool cmp(string a, string b) {
	return a.back() < b.back();
}

// 올바른 const, reference 사용
bool cmp(const string& a, const string& b) {
	return a.back() < b.back();
}

 

 

 

3. 시간복잡도

sort 함수는 O(nlogn)을 보장한다. 따라서 시간복잡도는 O(nlogn)이고, 시간제한 2초에 n<=50 이므로 통과 가능하다. 

 

 

 

'코딩테스트 > BOJ' 카테고리의 다른 글

[BOJ / C++] 감시 (시뮬레이션)  (0) 2025.07.19
[BOJ / C++] 카드 (정렬)  (0) 2025.07.18
[BOJ / C++] 배열 합치기 (정렬)  (0) 2025.07.16
[BOJ / C++] 재귀함수가 뭔가요? (재귀)  (0) 2025.07.15
[BOJ / C++] 벽 부수고 이동하기 (BFS로 풀이, 완전탐색 X)  (0) 2025.07.15
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ / C++] 감시 (시뮬레이션)
  • [BOJ / C++] 카드 (정렬)
  • [BOJ / C++] 배열 합치기 (정렬)
  • [BOJ / C++] 재귀함수가 뭔가요? (재귀)
sophon
sophon
sophon 님의 블로그 입니다.
  • sophon
    sophon 님의 블로그
    sophon
    • 카테고리 (173) N
      • 컴퓨터공학 (36)
        • 데이터베이스 (19)
        • 네트워크 (15)
        • 기타 이슈 (2)
      • 프로젝트 (16)
        • Java (8)
        • Spring (4)
        • Docker (4)
        • AI Agent (0)
      • 코딩테스트 (96) N
        • BOJ (74)
        • 프로그래머스 (7)
        • 프로그래머스 SQL (13) N
        • PS Snippets (2)
      • 🌱 잡담 (22)
        • 자격증 (7)
        • 좋은 시 모음 (12)
        • 책과 영화 (3)
        • 기록 (0)
  • 전체
    오늘
    어제
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 최근 글

  • hELLO· Designed By정상우.v4.10.6
sophon
[BOJ / C++] 시리얼 번호 (정렬)
상단으로

티스토리툴바