문제 설명 : 숨어있는 숫자의 덧셈(2)
문자열 my_string이 매개변수로 주어집니다.
my_string은 소문자, 대문자, 자연수로만 구성되어있습니다.
my_string 안의 자연수들의 합을 return 하는 solution 함수???
제한 사항
- 1 ≤ my_string의 길이 ≤ 1,000
- 1 ≤ my_string 안의 자연수 ≤1000
- 연속된 수는 하나의 숫자로 간주합니다.
- 000123과 같이 0이 선행하는 경우는 없습니다.
- 문자열에 자연수가 없는 경우 0을 return 해주세요.
입출력 예
my_string | result |
"aAb1B2cC34oOp" | 37 |
"1a2b3c4d123Z" | 133 |
문제 풀이
정규식을 이용해서 (아래 참조블로그에 자세히 나와있다.)
영문자를 구분자로해서 my_string문자열을 배열로 만들어준다음
그 배열안에 원소들을 다 더해줬다. 더해 줄때 *1을 한 것은 string이기 때문에 number로 바꿔준 것임
function solution(my_string) {
var answer = 0
let arr = my_string.split(/[a-z]/gi)
for(let i = 0; i < arr.length; i++) {
answer += arr[i] * 1
}
return answer
}
정규식 참조 : https://hamait.tistory.com/342
정규표현식 (Regex) 정리
정규표현식은 아주 가끔 쓰기때문에 항상 다시 볼때마다 헷갈리곤 하기에 주요 사용예를 내가 나중에 다시 봤을 때 편하도록 정리하여 보았다. 정규 표현식의 용어들정규 표현식에서 사용되는
hamait.tistory.com
문제 설명 : 진료순서 정하기
외과의사 머쓱이는 응급실에 온 환자의 응급도를 기준으로 진료 순서를 정하려고 합니다.
정수 배열 emergency가 매개변수로 주어질 때,
응급도가 높은 순서대로 진료 순서를 정한 배열을 return 하는 solution 함수???
제한 사항
- 중복된 원소는 없습니다.
- 1 ≤ emergency 의 길이 ≤ 10
- 1 ≤ emergency 의 원소 ≤ 100
입출력 예
emergency | result |
[3, 76, 24] | [3, 1, 2] |
[1, 2, 3, 4, 5, 6, 7] | [7, 6, 5, 4, 3, 2, 1] |
[30, 10, 23, 6, 100] | [2, 4, 3, 5, 1] |
문제 풀이
slice로 얕은 복사를 해줘서 원본이 변하지 않게 내림차순 배열(sortArr)을 하나 만들었다.
그 후에 map을 이용해서 emergency 원소들의 위치를 sortArr에서 indexOf로 찾고,
순서를 매기는 것이지만 인덱스는 0부터 시작하므로 찾은 값에 +1을 해준 배열을 만들어서 반환했다.
function solution(emergency) {
let sortArr = emergency.slice().sort((a,b) => b - a)
return emergency.map((num) => sortArr.indexOf(num) + 1)
}
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
'Programmers' 카테고리의 다른 글
Programmers 문제 풀이 38 (0) | 2023.08.22 |
---|---|
Programmers 문제 풀이 37 (0) | 2023.08.21 |
Programmers 문제 풀이 35 (0) | 2023.08.06 |
Programmers 문제 풀이 34 (0) | 2023.08.02 |
Programmers 문제 풀이 33 (0) | 2023.07.31 |