하루하루 꾸준히, 인생은 되는대로

자료구조

백준 1755 C++

긤효중 2022. 3. 19. 14:13

https://www.acmicpc.net/problem/1755

 

1755번: 숫자놀이

79를 영어로 읽되 숫자 단위로 하나씩 읽는다면 "seven nine"이 된다. 80은 마찬가지로 "eight zero"라고 읽는다. 79는 80보다 작지만, 영어로 숫자 하나씩 읽는다면 "eight zero"가 "seven nine"보다 사전순으로

www.acmicpc.net


문제

79를 영어로 읽되 숫자 단위로 하나씩 읽는다면 "seven nine"이 된다. 80은 마찬가지로 "eight zero"라고 읽는다. 79는 80보다 작지만, 영어로 숫자 하나씩 읽는다면 "eight zero"가 "seven nine"보다 사전순으로 먼저 온다.

문제는 정수 M, N(1 ≤ M ≤ N ≤ 99)이 주어지면 M 이상 N 이하의 정수를 숫자 하나씩 읽었을 때를 기준으로 사전순으로 정렬하여 출력하는 것이다.


입력

첫째 줄에 M과 N이 주어진다.


출력

M 이상 N 이하의 정수를 문제 조건에 맞게 정렬하여 한 줄에 10개씩 출력한다.


전체 소스 코드->

#include <iostream>
#include <string>
#include <algorithm>
 
using namespace std;
 
struct numcard{
    int value;
    string card;
};
 
bool compare(struct numcard a,struct numcard b){
    return a.card < b.card;
}
int main(void){
 
    int n;
    int M;
    cin >> n >> M;
   struct numcard arr[100];
    int index = 0;
 
    for(int i = n;i<=M;i++){
        string temp = to_string(i);
        string sum = "";
        for(int j = 0;j<temp.size();j++){
                  if(temp[j] == '0'){
                      sum = sum + "zero";
                  }
            else if(temp[j] == '1'){
                sum = sum + "one";
            }
            else if(temp[j] == '2'){
                sum = sum + "two";
            }
            else if(temp[j] == '3'){
                sum = sum + "three";
            }
            else if(temp[j] == '4'){
                sum = sum + "four";
            }
            else if(temp[j] == '5'){
               sum = sum + "five";
            }
            else if(temp[j] == '6'){
                sum = sum + "six";
            }
            else if(temp[j] == '7'){
                sum = sum + "seven";
            }
            else if(temp[j] == '8'){
                sum = sum + "eight";
            }
            else if(temp[j] == '9'){
                sum = sum + "nine";
            }
 
        }
        arr[index].value = i;
        arr[index].card = arr[index].card + sum;
        index++;
    }
    sort(arr,arr+index,compare);
 
    for(int i = 0;i<index;i++){
       cout << arr[i].value << " ";
        if(i%10 == 9){
            cout << '\n';
        }
 
    }
 
 
 
 
}

'자료구조' 카테고리의 다른 글

C++ Priority queue 컨테이너 사용법  (0) 2022.03.25
STD::multimap  (0) 2022.03.19
백준 전화번호 목록 C++  (0) 2022.03.17
백준 걸그룹 마스터 준석이 C++  (0) 2022.03.12
백준 숫자 카드 2 C++  (0) 2022.03.09