반응형
57. 특정한 문자를 대문자로 바꾸기
문제 설명
- 영소문자로 이루어진 문자열 my_string과 영소문자 1글자로 이루어진 문자열 alp가 매개변수로 주어질 때, my_string에서 alp에 해당하는 모든 글자를 대문자로 바꾼 문자열을 return 하는 solution 함수를 작성해 주세요.
제한사항
- 1 ≤ my_string의 길이 ≤ 1,000
입출력 예시
- 예제 1번의 my_string은 "programmers"이고 alp가 "p"이므로 my_string에 모든 p를 대문자인 P로 바꾼 문자열 "Programmers"를 return 합니다.
- 예제 2번의 alp는 "x"이고 my_string에 x는 없습니다. 따라서 "lowercase"를 return 합니다.
풀이
const solution = (my_string, alp) => {
let result = "";
for(const check of my_string){
if(check === alp){
result += check.toUpperCase();
} else {
result += check;
}
}
return result;
}
// 문자열을 저장할 result 선언
// for.. of 문을 이용하여 alp의 문자열과 같다면 대문자로 만들어준다.
// 그 외의 문자는 result에 그대로 저장한다.
58. 조건에 맞게 수열 변환하기 1
문제 설명
- 정수 배열 arr가 주어집니다. arr의 각 원소에 대해 값이 50보다 크거나 같은 짝수라면 2로 나누고, 50보다 작은 홀수라면 2를 곱합니다. 그 결과인 정수 배열을 return 하는 solution 함수를 완성해 주세요.
제한사항
- 1 ≤ arr의 길이 ≤ 1,000,000
- 1 ≤ arr의 원소의 값 ≤ 100
입출력 예시
- 1, 3은 50 미만의 홀수 이므로 2를 곱하고, 100, 98은 50 이상의 짝수이므로 2로 나눕니다.
- 나머지 값들은 변경 조건에 해당하지 않으므로 바꾸지 않습니다.
- 따라서 [2, 2, 6, 50, 99, 49]를 return 합니다.
풀이
const solution = arr => {
let result = [];
for(const num of arr){
if(num >= 50 && num % 2 === 0){
result.push(num/2);
}
else if(num < 50 && num % 2 === 1){
result.push(num*2);
}
else{
result.push(num);
}
}
return result;
}
// 새로운 배열 result 선언
// 각 조건에 따라 result에 값 할당 후 반환
59. 접두사인지 확인하기
문제 설명
- 어떤 문자열에 대해서 접두사는 특정 인덱스까지의 문자열을 의미합니다. 예를 들어, "banana"의 모든 접두사는 "b", "ba", "ban", "bana", "banan", "banana"입니다.
- 문자열 my_string과 is_prefix가 주어질 때, is_prefix가 my_string의 접두사라면 1을, 아니면 0을 return 하는 solution 함수를 작성해 주세요.
제한사항
- 1 ≤ my_string의 길이 ≤ 100
- 1 ≤ is_prefix의 길이 ≤ 100
- my_string과 is_prefix는 영소문자로만 이루어져 있습니다.
입출력 예시
- 예제 1번에서 is_prefix가 my_string의 접두사이기 때문에 1을 return 합니다.
- 예제 2번에서 is_prefix가 my_string의 접두사가 아니기 때문에 0을 return 합니다.
- 예제 3번에서 is_prefix가 my_string의 접두사가 아니기 때문에 0을 return 합니다.
- 예제 4번에서 is_prefix가 my_string의 접두사가 아니기 때문에 0을 return 합니다.
풀이
const solution = (my_string, is_prefix) => {
if(is_prefix.length > my_string.length) return 0;
for(let check = 0; check <is_prefix.length; check++){
if(is_prefix[check] !== my_string[check]) return 0;
}
return 1;
}
// is_prefix의 길이가 my_stirng 보다 크다면 접두사가 아니다.
// is_prefix와 my_string의 같은 인덱스 값을 비교했을 때 다르다면 접두사가 아니다.
- 정답률 높은 순부터 풀이
- 매일 3 문항 풀이
반응형
'프로그래머스 JS 코딩테스트' 카테고리의 다른 글
Lv0 JS 프로그래머스 #21 - n 번째 원소까지, n개 간격의 원소들, 대문자로 바꾸기 (40) | 2023.08.30 |
---|---|
Lv0 JS 프로그래머스 #20 - n의 배수, n 번째 원소부터, 카운트 업 (36) | 2023.08.29 |
Lv0 JS 프로그래머스 #18 - 문자열로 변환, 수 조작하기 1, 길이에 따른 연산 (33) | 2023.08.25 |
Lv0 JS 프로그래머스 #17 - 부분 문자열, 원하는 문자열 찾기, 글자 이어 붙여 문자열 만들기 (31) | 2023.08.24 |
Lv0 JS 프로그래머스 #16 - 정수 찾기, 문자열의 뒤의 n글자, 이어 붙인 수 (32) | 2023.08.23 |