반응형

java 85

[ 프로그래머스 ] 문자열 내림차순으로 배치하기 JAVA

문자열 내림차순으로 배치하기 문제 설명 문자열 s에 나타나는 문자를 큰것부터 작은 순으로 정렬해 새로운 문자열을 리턴하는 함수, solution을 완성해주세요. s는 영문 대소문자로만 구성되어 있으며, 대문자는 소문자보다 작은 것으로 간주합니다. 제한 사항 str은 길이 1 이상인 문자열입니다. 입출력 예 Zbcdefg gfedcbZ import java.util.ArrayList; import java.util.Collections; class Solution { public String solution(String s) { ArrayList list = new ArrayList(); for (int i = 0; i < s.length(); i++) { list.add(s.charAt(i)); } Co..

알고리즘 연습 2020.08.20

[ 프로그래머스 ] 문자열 다루기 기본 JAVA

문자열 다루기 기본 문제 설명 문자열 s의 길이가 4 혹은 6이고, 숫자로만 구성돼있는지 확인해주는 함수, solution을 완성하세요. 예를 들어 s가 a234이면 False를 리턴하고 1234라면 True를 리턴하면 됩니다. 제한 사항 `s`는 길이 1 이상, 길이 8 이하인 문자열입니다. 입출력 예 a234 false 1234 true class Solution { public boolean solution(String s) { if(s.length() == 4 || s.length() == 6) { for (int i = 0; i '9') return false; } return tr..

알고리즘 연습 2020.08.12

[ 프로그래머스 ] 수박수박수박수박수박수?

수박수박수박수박수박수? 문제 설명 길이가 n이고, 수박수박수박수....와 같은 패턴을 유지하는 문자열을 리턴하는 함수, solution을 완성하세요. 예를들어 n이 4이면 수박수박을 리턴하고 3이라면 수박수를 리턴하면 됩니다. 제한 조건 n은 길이 10,000이하인 자연수입니다. 입출력 예 3 수박수 4 수박수박 class Solution { public String solution(int n) { int m = n; StringBuilder sb = new StringBuilder(); while (n > 0) { if ((m - n) % 2 == 0) sb.append("수"); else sb.append("박"); n--; } return sb.toString(); } } StringBuilder를..

알고리즘 연습 2020.08.05

[ 프로그래머스 ] 문자열을 정수로 바꾸기 JAVA

문자열을 정수로 바꾸기 문제 설명 문자열 s를 숫자로 변환한 결과를 반환하는 함수, solution을 완성하세요. 제한 조건 s의 길이는 1 이상 5이하입니다. s의 맨앞에는 부호(+, -)가 올 수 있습니다. s는 부호와 숫자로만 이루어져있습니다. s는 0으로 시작하지 않습니다. 입출력 예 예를들어 str이 1234이면 1234를 반환하고, -1234이면 -1234를 반환하면 됩니다. str은 부호(+,-)와 숫자로만 구성되어 있고, 잘못된 값이 입력되는 경우는 없습니다. class Solution { public int solution(String s) { return Integer.parseInt(s); } } JAVA 언어를 사용하는 사람들에게는 너무 쉬운 문제입니다. Integer.parseIn..

알고리즘 연습 2020.08.05

[프로그래머스] 행렬의 덧셈 JAVA

행렬의 덧셈 문제 설명 행렬의 덧셈은 행과 열의 크기가 같은 두 행렬의 같은 행, 같은 열의 값을 서로 더한 결과가 됩니다. 2개의 행렬 arr1과 arr2를 입력받아, 행렬 덧셈의 결과를 반환하는 함수, solution을 완성해주세요. 제한 조건 행렬 arr1, arr2의 행과 열의 길이는 500을 넘지 않습니다. 입출력 예 arr1arr2return [[1,2],[2,3]] [[3,4],[5,6]] [[4,6],[7,9]] [[1],[2]] [[3],[4]] [[4],[6]] import java.util.Arrays; class Solution { public int[][] solution(int[][] arr1, int[][] arr2) { int[][] answer = new int[arr1.l..

알고리즘 연습 2020.03.29

[프로그래머스] 2018 KAKAO BLIND RECRUITMENT 1차 다트 게임

Q. 다트게임 출처 : https://programmers.co.kr/learn/courses/30/lessons/17682 카카오톡 게임별의 하반기 신규 서비스로 다트 게임을 출시하기로 했다. 다트 게임은 다트판에 다트를 세 차례 던져 그 점수의 합계로 실력을 겨루는 게임으로, 모두가 간단히 즐길 수 있다. 갓 입사한 무지는 코딩 실력을 인정받아 게임의 핵심 부분인 점수 계산 로직을 맡게 되었다. 다트 게임의 점수 계산 로직은 아래와 같다. 다트 게임은 총 3번의 기회로 구성된다. 각 기회마다 얻을 수 있는 점수는 0점에서 10점까지이다. 점수와 함께 Single(`S`), Double(`D`), Triple(`T`) 영역이 존재하고 각 영역 당첨 시 점수에서 1제곱, 2제곱, 3제곱 (점수1 , 점수..

알고리즘 연습 2020.03.16

[백준_BOJ] 2573. 빙산 _ JAVA

문제 풀이 빙산이 두 덩어리 이상으로 나뉘는 데에 걸리는 시간을 구하는 문제입니다. 이 문제를 풀이할 때 사용한 주요 로직은 위와 같습니다. while문을 이용해 빙산의 조각이 두 덩어리 이상으로 나뉘거나, 모두 녹아 사라질 때까지 반복합니다. 1. melting() : 빙산이 사라질 만큼을 계산해주어야 합니다. 계산을 위해 사용할 배열 copy를 만들어 준 뒤, 상, 하, 좌, 우에 위치한 0을 카운트하여 copy 배열에 저장해주었습니다. 2. calc() : 사라질 빙산이 계산되었다면, copy 배열의 정보를 이용해 빙산을 없애주었습니다. 빙산의 양보다 사라질 양이 많다면 0으로 저장하도록 해주었습니다. 3. checkLand() : 빙산의 덩어리 수를 계산하는 함수입니다. BFS를 이용하여 현재 맵..

알고리즘 연습 2019.12.31

[백준_BOJ] 4344. 평균은 넘겠지 _ JAVA

문제 풀이 가장 먼저 해야 할 일은 평균을 구하는 일인 것 같습니다. N을 입력받은 이후 for문을 이용해 sum변수에 입력되는 수의 총합을 구해줍니다. 그 다음, N으로 나누어서 평균값을 double형 변수 average에 저장해주었습니다. 이때 sum과 N이 int형 변수이기 때문에 sum앞에 '(double)' 실수형으로 강제 형변환해주었습니다. 다음으로 cnt 변수에 평균보다 높은 점수의 수를 세주었습니다. 이후 printf문을 이용해 소수점 3번째 자리까지 출력해주고 "%"를 붙여주었습니다. 로직은 간단하지만 형변환과 printf때문에 출력하기가 까다로운 문제였습니다. 코드 출처 https://www.acmicpc.net/problem/4344 4344번: 평균은 넘겠지 문제 대학생 새내기들의 ..

알고리즘 연습 2019.12.28

[백준_BOJ] 8958. OX퀴즈 _ JAVA

문제 풀이 입력으로 주어지는 문자열의 길이가 다르므로 int형 변수 size를 이용해 input의 길이를 저장합니다. 해당 길이만큼의 char 배열 array와 int형 배열 score를 만들어주었습니다. array에는 OX여부를 저장해두었고 score배열에는 각 단계별 얻을 수 있는 점수를 저장해주었습니다. 계산과정은 아래와 같습니다. 1. sum 변수는 가장 첫 문자가 O일 경우 1점, X일 경우 0점에서 시작합니다. 2. for문을 이용하여 1부터 size길이까지 i번째의 결과가 O라면, 바로 앞 단계(i-1번째)의 점수에 +1한 값을 sum에 더해줍니다. 3. for문이 종료된 뒤 sum 값을 출력해주었습니다. 코드 출처 https://www.acmicpc.net/problem/8958 8958번..

알고리즘 연습 2019.12.28

[백준_BOJ] 1546. 평균 _ JAVA

문제 풀이 간단히 평균을 조작하는 문제입니다. 평균을 조작하기 때문에 소수점 아래까지 다룰 수 있도록 double형으로 array를 만들어주었습니다. (N개) 입력 받으면서 가장 큰 점수를 찾아 max에 저장합니다. (이후 연산에 사용하기 위해) double형 변수 sum을 선언해주고 각각의 점수에 대해 array[i] / max * 100 연산을 처리해준 뒤 sum에 모두 더해줍니다. 마지막으로 sum을 N으로 나눈 결과값을 출력해주었습니다. 문제에서 주어지는 대로 배열을 이용해 입력받고 연산식을 그대로 적용하면 답을 찾을 수 있는 문제입니다. 단 소수점 두 번째 자리까지 정확성을 요구하므로 double형 변수를 이용해주었습니다. 코드 출처 https://www.acmicpc.net/problem/15..

알고리즘 연습 2019.12.28
반응형