알고리즘/JS 30

행렬의 덧셈

문제 설명 행렬의 덧셈은 행과 열의 크기가 같은 두 행렬의 같은 행, 같은 열의 값을 서로 더한 결과가 됩니다. 2개의 행렬 arr1과 arr2를 입력받아, 행렬 덧셈의 결과를 반환하는 함수, solution을 완성해주세요. 제한 조건 행렬 arr1, arr2의 행과 열의 길이는 500을 넘지 않습니다. 입출력 예 arr1 arr2 return [[1,2],[2,3]] [[3,4],[5,6]] [[4,6],[7,9]] [[1],[2]] [[3],[4]] [[4],[6]] 답 //어쩌다 풀렸는데 어떻게 돌아가는지 모르겠음 //map 함수를 쓰는 풀이가 있음 function solution(arr1, arr2) { var answer = [] for (let i=0; i

알고리즘/JS 2022.01.15

핸드폰 번호 가리기

문제 설명 프로그래머스 모바일은 개인정보 보호를 위해 고지서를 보낼 때 고객들의 전화번호의 일부를 가립니다. 전화번호가 문자열 phone_number로 주어졌을 때, 전화번호의 뒷 4자리를 제외한 나머지 숫자를 전부 *으로 가린 문자열을 리턴하는 함수, solution을 완성해주세요. 제한 조건 s는 길이 4 이상, 20이하인 문자열입니다. 입출력 예 phone_number return "01033334444" "*******4444" "027778888" "*****888 답 //나눠저있지 않은 배열을 변경하려고 하면 오류가 난다. 배열 값 하나를 나눠서 변경후 재 조립했다. //indxOf, splice, delete를 같이 사용하면 쉽게 배열을 변경할 수 있을 지도 중요한 건 splice? //re..

알고리즘/JS 2022.01.14

평균 구하기

정수를 담고 있는 배열 arr의 평균값을 return하는 함수, solution을 완성해보세요. 제한사항 arr은 길이 1 이상, 100 이하인 배열입니다. arr의 원소는 -10,000 이상 10,000 이하인 정수입니다. 입출력 예 arr return [1,2,3,4] 2.5 [5,5] 5 답 //=> 함수와 reduce 함수는 다른 문제에도 자주 나오고 코드를 많이 줄일 수 있더라 function solution(arr) { var answer = 0; let sum =0; for (let i=0; i

알고리즘/JS 2022.01.14

음수 양수 더하기

문제 설명 어떤 정수들이 있습니다. 이 정수들의 절댓값을 차례대로 담은 정수 배열 absolutes와 이 정수들의 부호를 차례대로 담은 불리언 배열 signs가 매개변수로 주어집니다. 실제 정수들의 합을 구하여 return 하도록 solution 함수를 완성해주세요. 제한사항 absolutes의 길이는 1 이상 1,000 이하입니다. absolutes의 모든 수는 각각 1 이상 1,000 이하입니다. signs의 길이는 absolutes의 길이와 같습니다. signs[i] 가 참이면 absolutes[i] 의 실제 정수가 양수임을, 그렇지 않으면 음수임을 의미합니다. 입출력 예 absolutes signs result [4,7,12] [true,false,true] 9 [1,2,3] [false,fals..

알고리즘/JS 2022.01.14

없는 숫자 더하기

문제 설명 0부터 9까지의 숫자 중 일부가 들어있는 배열 numbers가 매개변수로 주어집니다. numbers에서 찾을 수 없는 0부터 9까지의 숫자를 모두 찾아 더한 수를 return 하도록 solution 함수를 완성해주세요. 제한사항 1 ≤ numbers의 길이 ≤ 9 0 ≤ numbers의 모든 수 ≤ 9 numbers의 모든 수는 서로 다릅니다. 입출력 예 numbers result [1,2,3,4,6,7,8,0] 14 [5,8,4,0,6,7,9] 6 입출력 예 #1 5, 9가 numbers에 없으므로, 5 + 9 = 14를 return 해야 합니다. 입출력 예 #2 1, 2, 3이 numbers에 없으므로, 1 + 2 + 3 = 6을 return 해야 합니다. 답 function solutio..

알고리즘/JS 2022.01.14

문자열을 정수로 바꾸기

문제 설명 문자열 s를 숫자로 변환한 결과를 반환하는 함수, solution을 완성하세요. 제한 조건 s의 길이는 1 이상 5이하입니다. s의 맨앞에는 부호(+, -)가 올 수 있습니다. s는 부호와 숫자로만 이루어져있습니다. s는 "0"으로 시작하지 않습니다. 입출력 예 예를들어 str이 "1234"이면 1234를 반환하고, "-1234"이면 -1234를 반환하면 됩니다. str은 부호(+,-)와 숫자로만 구성되어 있고, 잘못된 값이 입력되는 경우는 없습니다. 답 function solution(s) { //다들 Math라는걸 많이 쓸길래 나도 한번 찾아서 써봤다. 알고리즘 연습하는데 이런 거 써도 되는 걸까? return(Math.trunc(s)) } MDN Math설명: https://develop..

알고리즘/JS 2022.01.14

두 정수 사이의 합

문제 설명 두 정수 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 답 function solution(a, b) { var answer = 0; if (a==b) { answer=a } else if (a

알고리즘/JS 2022.01.14

가운데 글자 가져오기

문제 단어 s의 가운데 글자를 반환하는 함수, solution을 만들어 보세요. 단어의 길이가 짝수라면 가운데 두 글자를 반환하면 됩니다. s는 길이가 1 이상, 100이하인 스트링입니다. 입출력 예 s return "abcde" "c" "qwer" "we" length를 이용해서 단어의 길이가 짝수인지 홀수인지 확인했습니다., 5자리 단어의 s.length / 2 는 2.5 이므로 -0.5합니다. s[2]자리의 단어가 표시됩니다.(0부터 시작합니다.) 6자리 단어의 s.length/2는 3입니다. 0부터 시작하므로 2가 나와야 합니다. -1 해줍니다. -> s[2] 짝수 단어는 가운데 두 글자를 출력해야 합니다. s[2] 다음 글자도 같이 출력하도록 +1한 결과도 추가합니다. s[2]+s[3] -> 가..

알고리즘/JS 2022.01.14