728x90
내 코드
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
// prices_len은 배열 prices의 길이입니다.
int* solution(int prices[], size_t prices_len) {
// return 값은 malloc 등 동적 할당을 사용해주세요. 할당 길이는 상황에 맞게 변경해주세요.
int* answer = (int*)malloc(sizeof(int)*prices_len);
int index = 0;
for(int i = 0; i < prices_len; i++) {
for(int j = i; j < prices_len; j++) {
index = j;
if(prices[i] > prices[j]) break;
}
answer[i] = index - i;
}
return answer;
}
코드는 20분 정도 간결하게 잘 짠듯.. 궁금한게 생겼는데 변수선언을 반복문 내에 하는게 좋을까 밖에 하는게 좋을까?
신뢰할만한 글은 없지만..
참고해보면 반복문 안에 선언하는 것이 가독성에 좋은뿐, 성능간의 문제는 없다고 하는데.. 믿어도 될까?
//1.
int num;
for(...) {
num = 1;
}
-------------
//2.
for(...) {
int num = 1;
}
전자의 경우, 메모리 상에 계속 존재하다 함수가 종료되면 같이 종료됨. 초기화는 여러번 되지만, 선언은 한 번.
후자의 경우, 반복문의 회차마다 생성과 초기화를 하게됨. 반복문이 끝나면 사라짐.
뭔가 전자가 더 좋을 것 같은데??
만약 글을 보게되는 천재는 댓글을 작성해줄 것..
'Algorism(PS) > 프로그래머스' 카테고리의 다른 글
[C] LV.2 삼각 달팽이 (0) | 2021.11.04 |
---|---|
[C] LV.1 없는 숫자 더하기 (8) | 2021.11.03 |
[C] LV.1 문자열을 정수로 바꾸기 (0) | 2021.11.03 |