[프로그래머스_1] 숫자 짝꿍 JAVA

2023. 4. 11. 22:41·알고리즘/알고리즘 풀이
반응형

 

프로그래머스

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

programmers.co.kr

 

CODE

import java.util.*;
class Solution {
    public String solution(String X, String Y) {
        StringBuilder answer = new StringBuilder();
        
        int[] xCntArr = new int[10];
        int[] yCntArr = new int[10];
        
        for(String x : X.split("")) {
            xCntArr[Integer.parseInt(x)]++;
        }
        for(String y : Y.split("")) {
            yCntArr[Integer.parseInt(y)]++;
        }
        
        for(int i = 9; i >= 0; i--) {
            while(xCntArr[i] > 0 && yCntArr[i] > 0) {
                answer.append(i);
                
                xCntArr[i]--;
                yCntArr[i]--;
            }
        }
        
        if("".equals(answer.toString())) return "-1";
        if("0".equals(answer.toString().substring(0, 1))) return "0";
        
        return answer.toString();
    }
}

맨 처음에 X, Y를 char 배열로 만든 후 정렬 > StringBuilder로 변환 > 정렬(내림차순) > for문으로 indexOf()로 찾음 이런 식으로 했다가 시간 초과 어택을 맞고 이것저것 찾아본 결과 힌트 중에 반복문의 기준을 X나 Y의 길이에 두지 말고, 어차피 0~9로 이루어진 숫자이니 이 숫자를 중심으로 생각하라는 힌트를 보고 코드 작성했다. 어려운 내용의 코드는 아니지만 시간 복잡도를 생각해볼 수 있는 좋은 문제였던 거 같다.

 

실행 결과

반응형
저작자표시 비영리 변경금지 (새창열림)
'알고리즘/알고리즘 풀이' 카테고리의 다른 글
  • [프로그래머스_1] 소수 찾기 JAVA
  • [프로그래머스_1] 소수 만들기 JAVA
  • [프로그래머스_1] 햄버거 만들기 JAVA
  • [프로그래머스_1] 2016 JAVA
데부한
데부한
어차피 할 거면 긍정적으로 하고 싶은 개발자
    반응형
  • 데부한
    동동이개발바닥
    데부한
  • 전체
    오늘
    어제
    • 분류 전체보기 (307)
      • 방통대 컴퓨터과학과 (27)
        • 잡담 (9)
        • 3학년1학기 (17)
      • 프로젝트 및 컨퍼런스 회고 (1)
        • 프로젝트 (4)
        • 한이음 프로젝트 (0)
        • 회고 (3)
      • 공부 (165)
        • Spring (37)
        • JPA (71)
        • 인프런 워밍업 클럽_BE (10)
        • Java (6)
        • React.js (27)
        • 넥사크로 (11)
        • 기타 (3)
      • 알고리즘 (85)
        • 알고리즘 유형 (10)
        • 알고리즘 풀이 (57)
        • SQL 풀이 (18)
      • 에러 해결 (13)
      • 잡담 (7)
        • 국비교육 (2)
        • 구매후기 (5)
        • 진짜 잡담 (0)
  • 블로그 메뉴

    • Github
    • Linkedin
    • 홈
    • 방명록
    • 글쓰기
    • 관리
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    코딩테스트
    운영체제
    SQL
    인프런
    react
    IT
    QueryDSL
    토이프로젝트
    RESTful
    SpringBoot를 이용한 RESTful Web Service 개발
    자바스크립트
    에러해결
    넥사크로
    프로그래머스
    Java
    알고리즘
    전자정부프레임워크
    백준
    Spring
    MSA
    JPA
    oracle
    기출문제
    스프링부트
    프론트엔드
    springboot
    토비의스프링부트
    egov
    개발자
    방통대
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
데부한
[프로그래머스_1] 숫자 짝꿍 JAVA
상단으로

티스토리툴바