8월 26, 2018의 게시물 표시

programmers level1 알고리즘 문제 - 문자열 내 p와 y의 개수

× 문자열 내 p와 y의 개수 대문자와 소문자가 섞여있는 문자열 s가 주어집니다. s에 'p'의 개수와 'y'의 개수를 비교해 같으면 True, 다르면 False를 return 하는 solution를 완성하세요. 'p', 'y' 모두 하나도 없는 경우는 항상 True를 리턴합니다. 단, 개수를 비교할 때 대문자와 소문자는 구별하지 않습니다. 예를들어 s가  pPoooyY 면 true를 return하고  Pyy 라면 false를 return합니다. 제한사항 문자열 s의 길이 : 50 이하의 자연수 문자열 s는 알파벳으로만 이루어져 있습니다. 입출력 예 s answer pPoooyY true Pyy false 입출력 예 설명 입출력 예 #1 'p'의 개수 3개, 'y'의 개수 3개로 같으므로 true를 return 합니다. 입출력 예 #2 'p'의 개수 1개, 'y'의 개수 2개로 다르므로 false를 return 합니다. class Solution { boolean solution ( String s ) { int pCnt = 0 , yCnt = 0 ; char [] ca = s . toCharArray (); for ( char ss : ca ){ if ( ss == 'y' || ss == 'Y' ){ yCnt += 1 ; } else if ( ss == 'p' || ss == 'P' ){ pCnt += 1 ; } } return yCnt == pCnt...

programmers level1 알고리즘 문제 - 서울에서 김서방 찾기

문제 설명 String형 배열 seoul의 element중  Kim 의 위치 x를 찾아,  김서방은 x에 있다 는 String을 반환하는 함수, solution을 완성하세요. seoul에  Kim 은 오직 한 번만 나타나며 잘못된 값이 입력되는 경우는 없습니다. 제한 사항 seoul은 길이 1 이상, 1000 이하인 배열입니다. seoul의 원소는 길이 1 이상, 20 이하인 문자열입니다. Kim 은 반드시 seoul 안에 포함되어 있습니다. 입출력 예 seoul return [ Jane ,  Kim ] 김서방은 1에 있다 class Solution { public String solution ( String [] seoul ) { String answer = "" ; int seq = 0 ; for ( int i = 0 ; i < seoul . length ; i ++ ) { if ( "Kim" . equals ( seoul [ i ]) ) { seq = i ; break ; } } answer = "김서방은 " + seq + "에 있다" ; return answer ; } }

programmers level1 알고리즘 문제 - 두 정수 사이의 합

문제 설명 두 정수 a, b가 주어졌을 때 a와 b 사이에 속한 모든 정수의 합을 리턴하는 함수, solution을 완성하세요. 예를 들어 a = 3, b = 5인 경우, 3 + 4 + 5 = 12이므로 12를 리턴합니다. 제한 조건 a와 b가 같은 경우는 둘 중 아무 수나 리턴하세요. a와 b는 -10,000,000 이상 10,000,000 이하인 정수입니다. a와 b의 대소관계는 정해져있지 않습니다. 입출력 예 a b return 3 5 12 3 3 3 5 3 12 class Solution { public long solution ( int a , int b ) { long answer = 0 ; if ( a < b ) { for (; a <= b ; a ++){ answer += a ; } } else for (; b <= a ; b ++){ answer += b ; }; return answer ; } }

programmers level1 알고리즘 문제 - 시저 암호

문제 설명 어떤 문장의 각 알파벳을 일정한 거리만큼 밀어서 다른 알파벳으로 바꾸는 암호화 방식을 시저 암호라고 합니다. 예를 들어  AB 는 1만큼 밀면  BC 가 되고, 3만큼 밀면  DE 가 됩니다.  z 는 1만큼 밀면  a 가 됩니다. 문자열 s와 거리 n을 입력받아 s를 n만큼 민 암호문을 만드는 함수, solution을 완성해 보세요. 제한 조건 공백은 아무리 밀어도 공백입니다. s는 알파벳 소문자, 대문자, 공백으로만 이루어져 있습니다. s의 길이는 8000이하입니다. n은 1 이상, 25이하인 자연수입니다. 입출력 예 s n result AB 1 BC z 1 a a B z 4 e F d class Solution { public String solution ( String s , int n ) { String answer = "" ; char [] alpha = s . toCharArray (); for ( char ss : alpha ) { if ( ss >= 97 && ss <= 122 ) { ss = ( char ) ( ss + n ); if ( ss >= 123 ) { int nn = ss - 122 - 1 ; ss = ( char ) ( 97 + nn ); } } else if ( ss >= 65 && ss <= 90 ) { ss = ( char ) ( ss + n ); ...