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

[코딩테스트 Lv.0] 문자 개수 세기

by 블루데이제이 2025. 3. 13.
728x90
반응형
문제 설명

알파벳 대소문자로만 이루어진 문자열 my_string이 주어질 때, my_string에서 'A'의 개수, my_string에서 'B'의 개수,..., my_string에서 'Z'의 개수, my_string에서 'a'의 개수, my_string에서 'b'의 개수,..., my_string에서 'z'의 개수를 순서대로 담은 길이 52의 정수 배열을 return 하는 solution 함수를 작성해 주세요.

제한사항
1 ≤ my_string의 길이 ≤ 1,000
입출력 예
my_string	result
"Programmers"	[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 2, 0, 1, 0, 0, 3, 1, 0, 0, 0, 0, 0, 0, 0]
입출력 설명
입출력 예 #1
예제 1번의 my_string에서 'P'가 1개, 'a'가 1개, 'e'가 1개, 'g'가 1개, 'm'이 2개, 'o'가 1개, 'r'가 3개, 's'가 1개 있으므로 [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 2, 0, 1, 0, 0, 3, 1, 0, 0, 0, 0, 0, 0, 0]를 return 합니다.

내 풀이
Java
class Solution {
    public int[] solution(String my_string) {
        int[] answer = new int[52];
        
        for(int i = 0; i < my_string.length(); i++){
            int n = (int) my_string.charAt(i);
            if(my_string.charAt(i) >= 'A' && my_string.charAt(i) <= 'Z'){
                answer[n - 65]++;
            }else{
                answer[n - 97 + 26]++;
            }
        }
        
        return answer;
    }
}
C
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>

// 파라미터로 주어지는 문자열은 const로 주어집니다. 변경하려면 문자열을 복사해서 사용하세요.
int* solution(const char* my_string) {
    // return 값은 malloc 등 동적 할당을 사용해주세요. 할당 길이는 상황에 맞게 변경해주세요.
    int* answer = (int*)malloc(sizeof(int) * 52);
    memset(answer, 0, sizeof(int)*52);
    int i;
    for(i = 0; i < strlen(my_string); i++){        
        if(my_string[i] >= 'A' && my_string[i] <= 'Z'){
            answer[my_string[i] - 65]++;
        }else{
            answer[my_string[i] - 97 + 26]++;
        }
    }
    
    return answer;
}
Python
def solution(my_string):
    answer = [0] * 52
    
    for i in my_string:
        if i >= 'A' and i <= 'Z':            
            answer[ord(i) - 65] += 1
        else:
            answer[ord(i) - 97 + 26] += 1    
    
    return answer

https://school.programmers.co.kr/learn/courses/30/lessons/181902

 

프로그래머스

SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프

programmers.co.kr

 

728x90
반응형