13일차 - 알고리즘 코드카타(시간초과)

2024. 7. 31. 11:16·Java & Spring/코딩테스트

- 진행

일자 완료 번호
24.07.16 1~20
24.07.17 21~35
24.07.18 36~42
24.07.19 43~47
24.07.22 48~50
24.07.23 51~55
24.07.24 56~57
24.07.25 58
24.07.26 59~60
24.07.29 61
24.07.30 62
24.07.31 63

- 회고

63. 숫자 짝꿍 https://school.programmers.co.kr/learn/courses/30/lessons/131128

 

프로그래머스

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

programmers.co.kr

- 풀이 과정

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);

        String x = sc.next();
        String y = sc.next();

        // x리스트 만들기
        List<String> xli = new ArrayList<>();
        for (int i = 0; i < x.length(); i++) {
            char c = x.charAt(i);
            xli.add(Character.toString(c));
        }

        // y리스트 만들기
        List<String> yli = new ArrayList<>();
        for (int i = 0; i < y.length(); i++) {
            char c = y.charAt(i);
            yli.add(Character.toString(c));
        }

        // 공통리스트 만들기
        List<String> cli = new ArrayList<>();
        List<String> temp = new ArrayList<>(yli);
        for (String S : xli) {
            if (temp.contains(S)) {
                temp.remove(S);
                cli.add(S);
            }
        }

        Collections.sort(cli, Collections.reverseOrder());
        StringBuilder answer = new StringBuilder();
        if (cli.size() == 0) {
            answer.append(-1);
        } else if (cli.get(0).equals("0")) {
            answer.append("0");
        } else {
            for (String S : cli) {
                answer.append(S);
            }
        }
        System.out.println(answer.toString());
    }
}
  1. 문자열 x,y를 순회하며 각 단어별 리스트 생성
  2. 두 문자열을 비교하며 공통리스트 생성
  3. 공통리스트를 내림차순 정렬하여 StringBuilder생성
    ※ 시간 초과 발생, 문자열이 3,000,000자리까지 있다보니 순회로 풀게되면 매우 오래걸림

- 개선 코드

class Solution {
    public String solution(String x, String y) {
        int[] xli = new int[10];
        int[] yli = new int[10];

        for (int i = 0; i < x.length(); i++) {
            char c = x.charAt(i);
            xli[c - '0']++;
        }

        for (int i = 0; i < y.length(); i++) {
            char c = y.charAt(i);
            yli[c - '0']++;
        }

        int[] answerArr = new int[10];
        for (int i = 0; i < 10; i++) {
            answerArr[i] = Math.min(xli[i], yli[i]);
        }

        StringBuilder answer = new StringBuilder();
        for (int i = 9; i >= 0; i--) {
            for (int j = 0; j < answerArr[i]; j++) {
                answer.append(i);
            }
        }

        if (answer.length() == 0) {
            return "-1";
        } else if (answer.charAt(0) == '0') {
            return "0";
        }
        return answer.toString();
    }
}
  1. 두 문자열의 숫자 출연 빈도를 크기 10짜리 배열에 위와같이 빈도체크
  2. 같은게 없는 경우와 0이두번오는 경우에 대한 조건문 작성

→ 해당 문제도 인덱스가 일정한(0~9)걸 활용 할 수 있는 문제였다.

'Java & Spring > 코딩테스트' 카테고리의 다른 글

15일차 - 알고리즘 코드카타  (1) 2024.08.05
14일차 - 알고리즘 코드카타  (0) 2024.08.01
12일차 - 알고리즘 코드카타(실패)  (0) 2024.07.31
11일차 - 알고리즘 코드카타  (0) 2024.07.29
10일차 - 알고리즘 코드카타  (0) 2024.07.26
'Java & Spring/코딩테스트' 카테고리의 다른 글
  • 15일차 - 알고리즘 코드카타
  • 14일차 - 알고리즘 코드카타
  • 12일차 - 알고리즘 코드카타(실패)
  • 11일차 - 알고리즘 코드카타
DJ.Kang
DJ.Kang
백엔드 개발 기록 블로그
  • DJ.Kang
    DJ Hello World
    DJ.Kang
  • 전체
    오늘
    어제
    • 분류 전체보기
      • 이론공부
      • 시스템설계
      • Java & Spring
        • TIL
        • 트러블슈팅
        • 고도화
        • 알고리즘
        • 코딩테스트
        • Java
        • Spring
        • Thymeleaf
      • 프로젝트
        • coin-trading
        • 트러블슈팅
      • Docker
      • DB
      • AWS
      • CI-CD
      • 웹
      • git & github
      • 구인공고분석
  • 블로그 메뉴

    • 홈
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    java 유클리드 호제법
    java enhance switch
    java
    java 멤버
    java기초
    데이터 타입
    프로그래머스 java 기초 트레이닝
    자료구조
    Java 생성자
    Java this
    java 세수의합
    java 에라토스테네스의 체
    개발로드맵
    프로그래머스 java 기초트레이닝
    java super
    java two-pointer
    java arrays.copyofrnage()
    java 제어자
    데이터 크기
    java 메서드
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.1
DJ.Kang
13일차 - 알고리즘 코드카타(시간초과)
상단으로

티스토리툴바