inflearn logo
강의

講義

知識共有

コーディングテスト本番模擬試験(with Java)

2. 2行N列再構成(2d Array)

유효한 솔루션이 없는 조건

199

youngjoon32021893

投稿した質問数 3

1

유효한 솔루션이 없는 경우를

colsum의 모든 값의 합이 upper + lower의 값과 다른 경우로 진행을 해보았는데, 결국에 결과값만 정확히 나오면 되는건가요!!?

public class Sec02 {

public static void main(String[] args) {

// TODO Auto-generated method stub

int upper = 2; 

    int lower = 2;

    String s = "";

    int[] colsum = {2, 1, 1};

    int sum = 0;

    int[][] result = new int[2][colsum.length];

    //유효성 체크방법, colsum의 각 배열 값의 총합과 upper + lower이 같은 경우만 실행

    //colsum의 총합 구하는 for문

    for(int i = 0 ; i < colsum.length ; i++) {

     sum += colsum[i];    

    }

    //colsum의 총합과 upper + lower이 같은 경우만 실행

    if(sum == (upper + lower)) {

      for(int i = 0 ; i < colsum.length ; i++) {

        //upper을 먼저 쓰는 로직으로 진행

        if(colsum[i] == 2) {

          upper--;

          lower--;

          result[0][i] = 1;

          result[1][i] = 1;

        }

        else if(colsum[i] == 1 && upper > 0) {

          upper--;

          result[0][i] = 1;

          result[1][i] = 0;

        }

        else if(colsum[i] == 1 ) {

          lower--;

          result[0][i] = 0;

          result[1][i] = 1;

        }

        else if(colsum[i] == 0) {

          result[0][i] = 0;

          result[1][i] = 0;

        }

          

      }

      //출력 구문

      s += "[";

      for(int i = 0 ; i < result.length ; i++) {

      

      for(int j = 0 ; j < result[i].length ; j++) {

      

      //배열의 시작일 경우, [를 넣어줌

      if(j == 0) {

      s += "[";

      }

      

      // String에 값을 넣어줌

      s += result[i][j];

      

      //upper , lower 배열의 끝이면 ]를, 그렇지 않으면 , 를 찍어주는 if문

      if(j == (result[i].length-1)) {

      s += "]";

      }

      else {

      s += ",";

      }

      

      

      }

      

      //배열 사이 ,를 찍는 IF문, 마지막 배열일시에는 찍지 않음

      if( i < result.length-1) {

      s += ",";

      }

      

      }

      s += "]";

      System.out.println(s);

    }

    

    //colsum의 총합과 upper + lower이 다를 경우 []값만 출력.

    else{

    System.out.println("[]");

    }

}

}

java 코테 준비 같이 해요!

回答 1

2

pushupman

진영준 안녕하세요?

이 문제는 2dArray ->List<List> 로 표시하는 문제로 자주 출제되고 있어서 중요한 문제죠 ^^

꼭 알아야할 개념입니다. 

질문주신 내용 :

유효한 솔루션이 없는 경우를 colsum의 모든 값의 합이 upper + lower의 값과 다른 경우로 진행을 해보았는데, 결국에 결과값만 정확히 나오면 되는건가요!!?

=> 유효한 솔루션이 없다는게 무슨 의미인지 정확히 모르겠습니다.^^

우리가 유효하게 솔루션을 만들어야 하는게 프로그래밍, 코딩이라고 생각하는데요 

그래서 말씀하신거처럼(아래그림참조) colsum = upper+lower 이렇게 되어야겠죠?

그리고 문제에서 리턴타입을 List<List<Integer>> 이걸로 맞춰 주셔야 합니다.

이문제는 List<List<Integer>>  <=> 이차원배열 변환 개념도 물어보는거라서, 

자유자재로 할 수 있어야 합니다.

주신소스를 보니 리스트 형태로 괄호 '[' 를 만드셨는데요, 연습삼아서 그렇게 하신거 같은데

이 문제는  List<List<Integer>>으로 리턴해주셔야 합니다.

setter 사용하지 않기

0

6

1

27:15 break 출력

0

8

1

세션을 제대로 이해한게 맞는지 궁금합니다

0

7

0

55강 파이썬에만있는 연산자들

0

18

2

55강의 파이썬에서만 있는 연산자들

0

20

2

안녕하세요 토비님 혹시 완성된 코드의 repository 주소는 없을까요?

0

19

1

강의 영상 업로드 질문

0

25

2

자막 오타 제보

0

25

1

운영환경에 적용해볼 수 없을때...고민입니다 ㅠㅠ

0

27

1

13 섹션 병렬 스트림 고급 1탄 매치 문의

0

34

2

29강 5:00

0

34

2

3차원 배열의 인덱스 해석 순서와 3중 반복문 순회 메커니즘에 대해 질문드립니다.

0

26

1

인텔리제이 설정 최신화 관련 확인 부탁 드립니다!

0

43

2

띄어쓰기

0

39

2

공부 순서

1

48

2

코딩 문제 사이트 접속 오류

0

28

1

재귀함수 연산법

0

33

2

동일성 동등성

0

27

1

다른 풀이방법질문

1

239

1

Priority Queue 대신 LinkedList 사용 이유를 알 수 있을까요??

1

379

2

result 가 없습니다.

1

250

1

영상 오디오가 너무 이상해요 ㅠㅠ

1

299

1

입출력 예시가 잘못된거 아닌가요??

1

176

2

가장 바깥 괄호제거

1

545

3