반응형
#문제6 하루 동안 엘리베이터가 멈춘 층이 순서대로 들어있는 배열이 있습니다. 이때, 엘리베이터의 총 이동거리를 구하려 합니다. 단, 층과 층 사이의 거리는 1입니다.
예를 들어 배열에 [1, 2, 5, 4, 2]가 들어있다면, 엘리베이터가 이동한 거리는 7입니다.
하루 동안 엘리베이터가 멈춰 선 층이 순서대로 들어있는 배열 floors와 floors의 길이 floors_len이 매개변수로 주어질 때, 엘리베이터의 총 이동 거리를 return 하도록 solution 함수를 작성하려 합니다. 빈칸을 채워 전체 코드를 완성해주세요.
#####매개변수 설명 하루 동안 엘리베이터가 멈춘 층이 순서대로 들어있는 배열 floors와 floors의 길이 floors_len이 solution 함수의 매개변수로 주어집니다.
- floors_len은 2 이상 100 이하의 자연수입니다.
- floors의 원소는 1 이상 100 이하의 자연수이며, 인접한 두 원소의 값이 같은 경우는 주어지지 않습니다.
- floors의 첫 번째 원소는 엘리베이터의 처음 위치를 나타냅니다.
#####return 값 설명 엘리베이터의 총 이동 거리를 return 해주세요.
#####예시
floors floors_len return
[1, 2, 5, 4, 2] | 5 | 7 |
#####예시 설명 엘리베이터는 처음에 1층에 있으며, 다음 순서대로 움직였습니다.
- 1층 - 2층 - 5층 - 4층 - 2층
층과 층사이의 거리는 1이므로, 엘리베이터가 이동한 거리는 다음과 같습니다.
- 1층 - 2층 (이동 거리 : 1)
- 2층 - 5층 (이동 거리 : 3)
- 5층 - 4층 (이동 거리 : 1)
- 4층 - 2층 (이동 거리 : 2)
따라서 총 이동 거리는 7입니다.
문제
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
int solution(int floors[], int floors_len) {
int dist = 0;
for(int i = @@@; @@@; ++i){
if(@@@)
dist += floors[i] - floors[i-1];
else
dist += floors[i-1] - floors[i];
}
return dist;
}
// 아래는 테스트케이스 출력을 해보기 위한 main 함수입니다.
int main() {
int floors[5] = {1, 2, 5, 4, 2};
int floors_len = 5;
int ret = solution(floors, floors_len);
// [실행] 버튼을 누르면 출력 값을 볼 수 있습니다.
printf("solution 함수의 반환 값은 %d 입니다.\\n", ret);
}
정답
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
int solution(int floors[], int floors_len) {
int dist = 0;
for(int i = 1; i < floors_len; ++i){
if(floors[i] > floors[i-1])
dist += floors[i] - floors[i-1];
else
dist += floors[i-1] - floors[i];
}
return dist;
}
내가 작성한 다른 정답
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
int solution(int floors[], int floors_len) {
int dist = 0;
for(int i = 0; i< floors_len-1; ++i){
if(floors[i] > floors[i+1])
dist += floors[i] - floors[i+1];
else
dist += floors[i+1] - floors[i];
}
return dist;
}
// 아래는 테스트케이스 출력을 해보기 위한 main 함수입니다.
int main() {
int floors[5] = {1, 2, 5, 4, 2};
int floors_len = 5;
int ret = solution(floors, floors_len);
// [실행] 버튼을 누르면 출력 값을 볼 수 있습니다.
printf("solution 함수의 반환 값은 %d 입니다.\\n", ret);
}
전꺼와 비교하든 다음꺼와 비교하든 상관은 없는거같다.
반응형
'Cos Pro 2급' 카테고리의 다른 글
Cos Pro 2급 2차_문제8번 C언어 (0) | 2024.03.30 |
---|---|
Cos Pro 2급 2차_문제7번 C언어 (0) | 2024.03.30 |
Cos Pro 2급 2차_문제5번 C언어 (0) | 2024.03.29 |
Cos Pro 2급 2차_문제4번 C언어 (0) | 2024.03.29 |
Cos Pro 2급 2차_문제3번 C언어 (0) | 2024.03.29 |