728x90
반응형
정수가 담긴 배열 numbers와 문자열 direction가 매개변수로 주어집니다. 배열 numbers의 원소를 direction방향으로 한 칸씩 회전시킨 배열을 return하도록 solution 함수를 완성해주세요.
제한사항
3 ≤ numbers의 길이 ≤ 20
direction은 "left" 와 "right" 둘 중 하나입니다.
입출력 예
numbers direction result
[1, 2, 3] "right" [3, 1, 2]
[4, 455, 6, 4, -1, 45, 6] "left" [455, 6, 4, -1, 45, 6, 4]
입출력 예 설명
입출력 예 #1
numbers 가 [1, 2, 3]이고 direction이 "right" 이므로 오른쪽으로 한 칸씩 회전시킨 [3, 1, 2]를 return합니다.
입출력 예 #2
numbers 가 [4, 455, 6, 4, -1, 45, 6]이고 direction이 "left" 이므로 왼쪽으로 한 칸씩 회전시킨 [455, 6, 4, -1, 45, 6, 4]를 return합니다.
내 풀이
[Java]
class Solution {
public int[] solution(int[] numbers, String direction) {
int[] answer = new int[numbers.length];
int temp = 0;
if(direction.equals("right")){
temp = numbers[numbers.length - 1];
for(int i = numbers.length - 1; i >= 1; i--){
answer[i] = numbers[i - 1];
}
answer[0] = temp;
}else if(direction.equals("left")){
temp = numbers[0];
for(int i = 0; i < numbers.length - 1; i++){
answer[i] = numbers[i + 1];
}
answer[numbers.length - 1] = temp;
}
return answer;
}
}
[C]
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
// numbers_len은 배열 numbers의 길이입니다.
// 파라미터로 주어지는 문자열은 const로 주어집니다. 변경하려면 문자열을 복사해서 사용하세요.
int* solution(int numbers[], size_t numbers_len, const char* direction) {
// return 값은 malloc 등 동적 할당을 사용해주세요. 할당 길이는 상황에 맞게 변경해주세요.
int* answer = (int*)malloc(sizeof(int)* numbers_len);
int temp = 0;
if(strcmp(direction, "right") == 0){
temp = numbers[numbers_len - 1];
for(int i = numbers_len - 1; i >= 1; i--){
answer[i] = numbers[i - 1];
}
answer[0] = temp;
}else if(strcmp(direction, "left") == 0){
temp = numbers[0];
for(int i = 0; i < numbers_len - 1; i++){
answer[i] = numbers[i + 1];
}
answer[numbers_len - 1] = temp;
}
return answer;
}
[Python]
def solution(numbers, direction):
answer = [0] * len(numbers)
temp = 0
if direction == "right":
temp = numbers[len(numbers) - 1]
for i in range(len(numbers) - 1, 0, -1):
answer[i] = numbers[i - 1]
answer[0] = temp
elif direction == "left":
temp = numbers[0]
for i in range(0, len(numbers) - 1):
answer[i] = numbers[i + 1]
answer[len(numbers) - 1] = temp
return answer
https://school.programmers.co.kr/learn/courses/30/lessons/120844
728x90
반응형
'코딩테스트 > 프로그래머스 입문' 카테고리의 다른 글
[코딩테스트 Lv.0] 합성수 찾기 (0) | 2024.01.22 |
---|---|
[코딩테스트 Lv.0] 주사위의 개수 (0) | 2024.01.20 |
[코딩테스트 Lv.0] 공 던지기 (0) | 2024.01.19 |
[코딩테스트 Lv.0] 2차원으로 만들기 (0) | 2024.01.19 |
[코딩테스트 Lv.0] 점의 위치 구하기 (0) | 2024.01.17 |