본문 바로가기
코딩테스트/프로그래머스 입문

[코딩테스트 Lv.0] 배열 회전시키기

by 블루데이제이 2024. 1. 19.
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

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

728x90
반응형