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