본문 바로가기

Algorithm/Programers - Java

[프로그래머스(Java)] qr code / Stream

 

Level. 0

 

문제

두 정수 q, r과 문자열 code가 주어질 때, code의 각 인덱스를 q로 나누었을 때 나머지가 r인 위치의 문자를 앞에서부터 순서대로 이어 붙인 문자열을 return 하는 solution 함수를 작성해 주세요.

* 제한사항
- 0 ≤ r < q ≤ 20
- r < code의 길이 ≤ 1,000
- code는 영소문자로만 이루어져 있습니다.

 

 

풀이

import java.util.stream.*;
class Solution {
    public String solution(int q, int r, String code) {
		
        String answer = "";
        
        for(int i=0; i<code.length(); i++){
            if(i%q==r) answer += code.charAt(i);
        }
        return answer;
    }
}

 

 

다른 풀이

import java.util.stream.*;
class Solution {
    public String solution(int q, int r, String code) {

        return IntStream.range(0, code.length()).filter(c->c%q==r).mapToObj(i->String.valueOf(code.charAt(i))).collect(Collectors.joining());

    }
}

 

 


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

 

프로그래머스

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

programmers.co.kr