Skip to content

MangKyu/stream-quiz

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

29 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Stream API 문제 풀어보기

위의 문제를 직접 풀어보고 정답이 맞는지 비교가능하도록 프로젝트를 구성해두었습니다. 이번에는 직접 문제를 풀어보고 정답이 맞는지 확인하는 방법에 대해 알아보도록 하겠습니다.

1. 프로젝트를 클론받는다.

해당 문제를 직접 풀고 정답을 비교해보기 위해서는 프로젝트를 클론받아야 합니다.
이 링크 를 통해 깃 프로젝트를 클론합니다.



2. 원하는 문제 풀어보기

소스 코드에 문제 번호대로 다음과 같이 패키지 구성 및 클래스 생성을 해두었습니다.
만약 1.1번 문제를 풀어보고 싶다면 Quiz1 클래스의 quiz1 메소드를 구현하면 됩니다.



3. 정답이 맞는지 검사하기

해당 문제를 풀었다면 곧바로 검증할 수 있도록 자동화된 테스트를 작성해두었습니다.
만약 1.1번 문제를 풀었고, 정답을 확인해보고 싶다면 Quiz1Test의 quiz1 테스트를 실행해보면 됩니다.
정답은 Answer 클래스에 작성해두었으니 정답 확인은 Answer 클래스를 참고하면 됩니다.


만약 문제를 정상적으로 풀었다면 다음과 같이 테스트가 통과하게 됩니다.




Stream API에 입문하시는 많은 분들에게 도움이 되었으면 좋겠네요!
잘 보셨다면 깃허브 스타 부탁드리겠습니다! 감사합니다:)



Stream 문제


문제1

아래와 같은 User.csv가 있다고 할 때, 아래의 CSV 데이터를 조회하여 아래와 같은 결과를 출력한다고 하자.

//User.csv
이름, 취미, 소개
김프로, 축구:농구:야구, 구기종목 좋아요
정프로, 개발:당구:축구, 개발하는데 뛰긴 싫어
앙몬드, 피아노, 죠르디가 좋아요 좋아좋아너무좋아
죠르디, 스포츠댄스:개발, 개발하는 죠르디 좋아
박프로, 골프:야구, 운동이 좋아요
정프로, 개발:축구:농구, 개발도 좋고 운동도 좋아

문제 1.1

위와 같은 데이터를 조회하여 각 취미를 선호하는 인원이 몇 명인지 계산하여라.

문제 1.2

위와 같은 데이터를 조회하여 각 취미를 선호하는 정씨 성을 갖는 인원이 몇 명인지 계산하여라.

문제 1.3

위와 같은 데이터를 조회하여 소개 내용에 '좋아'가 몇번 등장하는지 계산하여라.


문제2

아래와 같은 데이터가 저장된 리스트가 있다고 하자.

private final static List<String> WORDS = Arrays.asList("TONY", "a", "hULK", "B", "america", "X", "nebula", "Korea");

문제 2.1

List에 저장된 단어들의 접두사가 각각 몇개씩 있는지 Map<String, Integer>으로 변환하여라. ex) ("T", 1), ("a", 2) ...

문제 2.2

List에 저장된 단어들 중에서 단어의 길이가 2 이상인 경우에만, 모든 단어를 대문자로 변환하여 스페이스로 구분한 하나의 문자열로 합한 결과를 반환하여라. ex) ["Hello", "a", "Island", "b"] -> “H I”


문제 3

private static final List<Integer> numbers1 = Arrays.asList(1, 2, 3);
private static final List<Integer> numbers2 = Arrays.asList(3, 4);

문제 3.1

위와 같은 숫자 리스트가 있을 때 모든 숫자 쌍의 배열 리스트를 반환하여라. ex) numbers1 = [1,2,3], numbers2 = [3,4] -> [(1,3), (1,4), (2,3), (2,4), (3,3), (3,4)]


문제 3.2

위와 같은 숫자 리스트가 있을 때 모든 숫자 쌍의 곱이 가장 큰 값을 반환하여라. ex) numbers1 = [1,2,3], numbers2 = [3,4] -> 12



문제4

아래와 같은 데이터를 갖는 거래자와 거래 내역 클래스가 있다고 하자. (생성자 및 Getter, Setter 등은 생략)

public class Trader {
    private String name;
    private String city;
}

public class Transaction {
    private Trader trader;
    private int year;
    private int value;
}

또한 데이터는 아래와 같이 초기화되어 있다.

public void init() {
    Trader kyu = new Trader("Kyu", "Seoul");
    Trader ming = new Trader("Ming", "Gyeonggi");
    Trader hyuk = new Trader("Hyuk", "Incheon");
    Trader hwan = new Trader("Hwan", "Busan");
    transactions = Arrays.asList(
            new Transaction(kyu, 2019, 30000),
            new Transaction(kyu, 2020, 12000),
            new Transaction(ming, 2020, 40000),
            new Transaction(ming, 2020, 7100),
            new Transaction(hyuk, 2019, 5900),
            new Transaction(hwan, 2020, 4900)
    );
}

문제 4.1

2020년에 일어난 모든 거래 내역을 찾아 거래값을 기준으로 오름차순 정렬하라.

문제 4.2

거래 내역이 있는 거래자가 근무하는 모든 도시를 중복 없이 나열하라.

문제 4.3

서울에서 근무하는 모든 거래자를 찾아서 이름순서대로 정렬하라.

문제 4.4

모든 거래자의 이름을 구분자(",")로 구분하여 정렬하라.

문제 4.5

부산에 거래자가 있는지를 확인하라.

문제 4.6

서울에 거주하는 거래자의 모든 거래 금액을 구하라.

문제 4.7

모든 거래 내역중에서 거래 금액의 최댓값과 최솟값을 구하라. 단, 최댓값은 reduce를 이용하고 최솟값은 stream의 min()을 이용하라.



문제 5

문제 5.1

문자열 배열 String[] strArr = {"aaa","bb","c","dddd"}의 모든 문자열의 길이를 더한 결과를 출력하여라.


문제 5.2

문자열 배열 String[] strArr = {"aaa","bb","c","dddd"}의 문자열 중에서 가장 긴 것의 길이를 출력하시오.


문제 5.3

임의의 로또번호(1~45)를 정렬해서 출력하시오.


문제 5.4

두 개의 주사위를 굴려서 나온 눈의 합이 6인 경우를 모두 출력하시오.



문제 6

아래와 같은 학생 클래스가 있다고 하자. (생성자 및 Getter 등은 생략)

public class Student {

    private String name;
    private boolean isMale; // 성별
    private int hak; // 학년
    private int ban; // 반
    private int score;

    public String toString() {
        return String.format("[%s, %s, %d학년 %d반, %3d점 ]", name, isMale ? "남" : "여", hak, ban, score);
    }
}

또한 데이터는 Student[] stuArr에 저장되어 있다.

문제 6.1

stuArr에서 불합격(150점 미만)한 학생의 수를 남자와 여자로 구별하여라. (Boolean, List)

문제 6.2

각 반별 총점을 학년 별로 나누어 구하여라 (Map<Integer, Map<Integer, Integer>>)




참고 자료

About

Java의 Stream API 연습을 위한 레포지토리

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages