Algorithm/Programmers
프로그래머스 ) 길이에 따른 연산 [JAVA] - 오늘의 TIL
그리밍밍
2023. 9. 30. 21:35
https://school.programmers.co.kr/learn/courses/30/lessons/181879
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
👇소스 코드
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
// num_list_len은 배열 num_list의 길이입니다.
int solution(int num_list[], size_t num_list_len) {
int answer = 0;
if( num_list_len >= 11){
for(int i=0; i<num_list_len; i++){
answer += num_list[i];
}
} else {
answer = 1;
for(int i=0; i<num_list_len; i++){
answer *= num_list[i];
}
}
return answer;
}
🐣코드 설명
- num_list의 길이는 num_list_len으로 주어졌기 때문에 그것을 활용하였다.
- if문을 사용하여 num_list의 길이가 11이상일 경우( >= ) 아닐경우를 작성해주었고
- 그 안에 for문을 돌려서
case1) 11이상일 경우 answer이라는 변수에 num_list의 값들을 차곡차곡 더해주었고
case2) 11이상이 아닐 경우 answer이라는 변수에 num_list의 값들을 차곡차곡 곱해주는데
여기서 주의할 점은 answer은 처음 선언됬을 때 0으로 선언되었기 때문에 무슨 수를 곱해줘도 0이 된다.
이것을 해결하기 위해서는 answer이 1이 되어야하는데 그것을 else안 for문 돌리기 전에 선언해주어 해결하였다.
728x90