프로그래밍 공부
작성일
2024. 1. 30. 20:48
작성자
WDmil
728x90

문제 설명

전화번호부에 적힌 전화번호 중, 한 번호가 다른 번호의 접두어인 경우가 있는지 확인하려 합니다.

전화번호가 다음과 같을 경우, 구조대 전화번호는 영석이의 전화번호의 접두사입니다.

 

구조대 : 119

박준영 : 97 674 223

지영석 : 11 9552 4421

전화번호부에 적힌 전화번호를 담은 배열 phone_book solution 함수의 매개변수로 주어질 때, 어떤 번호가 다른 번호의 접두어인 경우가 있으면 false를 그렇지 않으면 true return 하도록 solution 함수를 작성해주세요.

 

제한 사항

  • phone_book의 길이는 1 이상 1,000,000 이하입니다.
  • 각 전화번호의 길이는 1 이상 20 이하입니다.
  • 같은 전화번호가 중복해서 들어있지 않습니다.

입출력 예제

phone_book return
["119", "97674223", "1195524421"] false
["123","456","789"]  true
["12","123","1235","567","88"] false

 


문제 풀이

전화번호의 다른 번호의 접두어인 경우가 있는지 확인하려 한다.

들어간 전화번호 중, 중복된 전화번호가 존재하는지 확인하려고 하는 문제이다.

 

탐색알고리즘에서 가장 효율적 인것은 헤시키 값 이고, 그 다음이 트리 구조이다.

 

트리구조로 탐색하도 무방하고, 해시를 사용해도 무방하다.

 

그냥 모든 키값의 string값을 순환하면서 0~현재 문자까지의 모든 문자를 순환하면서 해시값으로 데이터를 확인하고, 해당 데이터에 +1을 해준 뒤에, 들어온 모든 문자열을 확인하면서 1 이상인 값이 있다면, false 아니면 true를 반환하면 된다.

매우 쉬운 문제.


첫 시도

#include <string>
#include <vector>
#include <unordered_map>

using namespace std;

bool solution(vector<string> phone_book) {
    unordered_map<string, int> answer_map;
    for(const string& phone_number : phone_book)
    {
        for(int i = 0; i < phone_number.size(); i++)
        {
            string input = phone_number.substr(0, i);
            answer_map[input] += 1;
        }
    }
    for(const string& phone_number : phone_book)
        if(answer_map[phone_number] >= 1)
            return false;
    
    return true;
}

성공

 

위 설명과 같이. 그냥 unordered_map을 생성하고, string -> string.size() 로 순환하면서 모든 문자열에 대해 중복되는 경우가 생기는 것을 헤시키로 중복처리하고 데이터를 기입. 그리고 1을 더해준다음.

 

입력받은 모든 숫자열에 대해 1 이상인 경우가 존재하면 false로 처리. 아니라면 true로 처리한다.

728x90

'코딩테스트 문제 풀이 > 해시' 카테고리의 다른 글

방문 길이  (0) 2024.03.29
베스트앨범  (0) 2024.02.13
의상  (0) 2024.02.07
폰켓몬  (0) 2024.01.18
완주하지 못한 선수  (0) 2024.01.10