위지원의 데이터 일기 🐈
Home
  • 분류 전체보기 (563)
    • ✎ 2025년 (4)
    • 2024년 (16)
    • 2023년 (6)
    • 2022년 (35)
      • Developement (22)
      • Error (9)
    • 2021년 (68)
      • ERROR (9)
      • 알고리즘 (11)
      • 개발공부 (21)
      • Data (15)
      • 21.下 (12)
    • 2020년 (164)
      • 코테 (84)
      • Development (29)
      • 정처기 (41)
    • 2019년 (27)
    • 2018년 (89)
      • English Speaking (8)
      • Error (12)
      • C, Java, FileSystem (13)
      • DataBase (15)
      • Java (2)
      • 지식 (16)
      • Go (3)
      • spark (9)
      • 영어 (5)
      • 알고리즘 (6)
    • 2017년 (143)
      • Error (17)
      • machine learning (16)
      • Spark (20)
      • Database (19)
      • Python (17)
      • Spring (9)
      • etc. (10)
      • 백준 (5)
      • Google Platform (12)
      • web Development (7)
      • Docker (3)
      • Linux (8)
Home
  • 분류 전체보기 (563)
    • ✎ 2025년 (4)
    • 2024년 (16)
    • 2023년 (6)
    • 2022년 (35)
      • Developement (22)
      • Error (9)
    • 2021년 (68)
      • ERROR (9)
      • 알고리즘 (11)
      • 개발공부 (21)
      • Data (15)
      • 21.下 (12)
    • 2020년 (164)
      • 코테 (84)
      • Development (29)
      • 정처기 (41)
    • 2019년 (27)
    • 2018년 (89)
      • English Speaking (8)
      • Error (12)
      • C, Java, FileSystem (13)
      • DataBase (15)
      • Java (2)
      • 지식 (16)
      • Go (3)
      • spark (9)
      • 영어 (5)
      • 알고리즘 (6)
    • 2017년 (143)
      • Error (17)
      • machine learning (16)
      • Spark (20)
      • Database (19)
      • Python (17)
      • Spring (9)
      • etc. (10)
      • 백준 (5)
      • Google Platform (12)
      • web Development (7)
      • Docker (3)
      • Linux (8)
블로그 내 검색
포트폴리오

위지원의 데이터 일기 🐈

데이터를 사랑하고 궁금해하는 기록쟁이입니다! 😉 Super Data Girl이 되는 그날까지🏃‍♀️ 화이팅!

  • 🖥 깃블로그
  • 🌍 위키원
  • 📑 내맘대로 스크랩
  • 💌 메일
  • 2020년/코테

    [코테 연습] 가장 큰수

    2020. 9. 15. 11:13

    by. 위지원

    programmers.co.kr/learn/courses/30/lessons/42746#

     

    코딩테스트 연습 - 가장 큰 수

    0 또는 양의 정수가 주어졌을 때, 정수를 이어 붙여 만들 수 있는 가장 큰 수를 알아내 주세요. 예를 들어, 주어진 정수가 [6, 10, 2]라면 [6102, 6210, 1062, 1026, 2610, 2106]를 만들 수 있고, 이중 가장 큰 ��

    programmers.co.kr

    0 또는 양의 정수가 주어졌을 때, 정수를 이어 붙여 만들 수 있는 가장 큰 수를 알아내 주세요.

    예를 들어, 주어진 정수가 [6, 10, 2]라면 [6102, 6210, 1062, 1026, 2610, 2106]를 만들 수 있고, 이중 가장 큰 수는 6210입니다.

    0 또는 양의 정수가 담긴 배열 numbers가 매개변수로 주어질 때, 순서를 재배치하여 만들 수 있는 가장 큰 수를 문자열로 바꾸어 return 하도록 solution 함수를 작성해주세요.

     


     

    1차 시도.. 

    [모든 자리의 수를 더한 값, 자리수, 원래값] 으로 tuple을 만들어 sort 했다.

    여기서 자리수를 넣은이유가 3과 30같은 경우인데 이 둘은 더해도 3, 30으로 해서 330이 더 큰데 자칫 303이 되버려서였다..

     

     

    위와 같이 코딩을 진행하는 경우 (34, 5) 가 문제가 발생한다. 3+4 = 7 이고 5보다 크므로 534가 아니라 345가 만들어진다. 

    자릿수를 맞춰야하는가?

     

    • numbers의 원소는 0 이상 1,000 이하입니다.

    위와 같은 조건이 있다.. 음 그럼 4자리로 모두 맞춰도 되지 않을까.. 

     

    2차시도.. 자리 수를 맞춰주고 진행.. 여전히 통과하지 못한다. 

     

     

     

    질문 목록을 보니 나와 같이 1~6번을 틀린분들이 많이계셨다.

    programmers.co.kr/questions/12763

     

    프로그래머스

    코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

    programmers.co.kr

    이 분의 반례처럼 내 코드는 (40,403)의 입력값의 결과로 "40340"을 return하는 것을 확인할 수 있었다.

    자리수를 맞추면 (4000,4030) 이기때문에 4030이 더 큰값으로 여겨져 40340이 결과가 된다. 

     


    정답을 보다

    오랜 시간이 흐른 뒤.. 결국 답을 봤다. 그냥 숫자를 3번 곱해서 비교하면되는 것이였다. 

    그러면 위에 문제인

    - 404040 

    - 403403403

    이런식으로 해서 문자열 비교이기때문에 자리별로 비교하므로 40이 더 큰 값이 된다. 

    혹시나 해서 2번 곱했는데 그건 틀린다.1~6번까지 .. 아무튼 오늘 문자열 비교에 아주 획기적인 아이디어에 대해서 얻을 수 있었다. 

     


    다른 사람의 코드

    다른 사람의 코드도 발견했다.. 어머나.. 저렇게 한번에 곱해서 sort하는 방법이 있었다니.

     

     

     

    저작자표시 (새창열림)

    '2020년 > 코테' 카테고리의 다른 글

    [코테 연습] Length of Last Word  (0) 2020.09.15
    [코테 연습] House Robber  (0) 2020.09.15
    [코테 연습] Bulls and Cows  (0) 2020.09.14
    [코테연습] Combination Sum III  (0) 2020.09.14
    [코테 연습] Compare Version Numbers  (0) 2020.09.13

    잠깐만요~! 읽으신김에 이런 글들은 어떠세요? 👀

    • [코테 연습] Length of Last Word 2020.09.15
    • [코테 연습] House Robber 2020.09.15
    • [코테 연습] Bulls and Cows 2020.09.14
    • [코테연습] Combination Sum III 2020.09.14
    맨 위로
전체 글 보기
Tistory 로그인
Tistory 로그아웃
로그아웃 글쓰기 관리

열정! 열정! 열정! 🔥

Designed by Nana
블로그 이미지
위지원
데이터 엔지니어로 근무 중에 있으며 데이터와 관련된 일을 모두 좋아합니다!. 특히 ETL 부분에 관심이 가장 크며 데이터를 빛이나게 가공하는 일을 좋아한답니다 ✨

티스토리툴바

티스토리툴바