본문 바로가기

알고리즘

[Programmers] Level1. 같은 숫자는 싫어 (Java) Level1. 같은 숫자는 싫어 문제설명 ) 풀이Code ) import java.util.*; public class Solution { public int[] solution(int []arr) { int listCnt = 0; // list 가 담겨질 index 카운트 ArrayList list = new ArrayList(); // 비교할 값들을 담을 list list.add(arr[0]); // 초기에 arr 첫번째 인덱스의 값 넣어주기 for(int i=1; i 더보기
[Programmers] Level1. 가운데 글자 가져오기 (Java) Level1. 가운데 글자 가져오기 문제설명 ) 풀이Code ) class Solution { public String solution(String s) { String answer = ""; if (s.length() % 2 == 0) { // 짝수일때 answer = s.substring((s.length()/2) - 1, (s.length()/2) + 1); } else { answer = s.substring(s.length()/2, (s.length()/2) + 1); } return answer; } } 풀이 2 ) class Solution { public String solution(String s) { String answer = ""; answer = s.length() % 2 == 0.. 더보기
[Programmers] Level1. 2016년 (Java) Level1. 2016년 문제설명 ) 풀이Code ) 더보기 class Solution { public String solution(int a, int b) { int[] month = {31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}; int day = 0; String[] week ={"FRI","SAT","SUN","MON","TUE","WED","THU"}; String answer = ""; for (int i=0; i1 ? ((b-1)%7) : 0; // 일주일 단위로 나눈 나머지값 int weekIndex = 0; // 최종적으로 요일의 인덱스 // addDays를 해줬을때 한 주를 넘어가게되면 일요일부터 다시계산해준다. // 수요일인데 addDays가 .. 더보기
[Programmers] Level1. K번째 수 (Java) Level1. K번째 수 문제설명 ) 풀이Code ) 더보기 import java.util.ArrayList; import java.util.Collections; class Solution { public int[] solution(int[] array, int[][] commands) { int[] answer = new int[commands.length]; // commands 의 수 만큼 return 해줄 배열 선언 ArrayList list = new ArrayList(); // 정렬 편하게 하기위한 list 생성 for (int i=0; i 더보기
[Programmers] Level1. 체육복 (Java) Level1. 체육복 문제설명 ) 풀이Code ) 더보기 class Solution { public int solution(int n, int[] lost, int[] reserve) { int answer = 0; int cnt = 0; for (int i=0; i 더보기
[Programmers] Level1. 완주하지 못한 선수 (Java) 문제설명 ) 풀이 CODE ) 더보기 import java.util.HashMap; class Solution { //두 개의 문자열 배열을 비교하여 중복되지않는 1개의 문자열 리턴 public String solution(String[] participant, String[] completion) { String answer = ""; //두개의 문자열 index 에 +1또는 -1을 해줄 Hash 선언 HashMap cnt = new HashMap(); //participant 의 인덱스에 맞춰 +1 for (String player : participant) { //getOrDefault 를 통하여 중복 검사 cnt.put(player, cnt.getOrDefault(player, 0) + 1); }.. 더보기
[Programmers] Level1. 모의고사 (Java) Level1. 모의고사 문제설명 ) 풀이Code ) 더보기 import java.util.ArrayList; public class Solution { public int[] solution(int[] answers) { int[] a = new int[] {1, 2, 3, 4, 5}; int[] b = new int[] {2, 1, 2, 3, 2, 4, 2, 5}; int[] c = new int[] {3, 3, 1, 1, 2, 2, 4, 4, 5, 5}; //제시된 정답규칙 int[] score = new int[3]; //세 학생의 점수 비교를 위한 배열 for (int i=0; i 더보기
두 개 뽑아서 더하기 import java.util.ArrayList; import java.util.Arrays; import java.util.List; public class Solution { public int[] solution(int[] numbers) { List list = new ArrayList(); for (int i=0; i 더보기