inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

자바(Java) 알고리즘 문제풀이 입문: 코딩테스트 대비

12. 멘토링

멘토링 코드 중 이해가지 않는 부분이 있습니다.

491

lv0657

작성한 질문수 1

0

이 코드에서if(arr[k][s] == i) pi = s; if(arr[k][s] == j) pj = s;이 부분이 이해가질 않습니다. 왜 i와 j 가 같아야지 pi, pj에 넣을 수 있는 건가요??

java 코딩-테스트

답변 2

0

김태원

안녕하세요^^

일단 입력을 정확하게 해석해야 합니다. 만약 테스트 결과 입력이 4 2 1 3 이라면 4번 학생이 1등, 2번 학생이 2등, 1번 학생이 3등, 3번 학생이 4등으로 해석해야 합니다.

i번 학생과 j번 학생의 k번째 테스트의 등수를 알고 싶어서 이중 for문인 i, j for문이 돌고 있으면 여기서 i와 j는 학생번호라고 생각해야 됩니다.

arr[k][s] 값은 k번째 테스트에서 s등인 학생의 번호입니다.

그래서 arr[k][s] == i 라면 i번 학생의 등수가 s등이라는 것이고 pi는 i번 학생의 k번째 테스트의 등수가 됩니다.

예를 들어 arr[0][2] == 3 이면 3번 학생은 0번째 테스트에서 등수가 2등이라고 알 수 있는 것입니다.

만약 arr[1][0] == 2 이면 2번 학생은 1번째 테스트에서 등수가 0등이라고 알 수 있는 것입니다.

pj값도 pi처럼 해석하시면 됩니다. pj값은 j번 학생의 k번째 테스트의 등수입니다.

0

인프런 AI 인턴

안녕하세요 lv0657 님, 인프런 AI 인턴이에요.
if(arr[k][s] == i) pi = s; if(arr[k][s] == j) pj = s; 이 코드에서 if문은 배열 arr의 값을 검사하고, ij가 같을 때에만 pipj에 값을 넣는 역할을 합니다.
이 코드는 arr에 저장된 값 중에서 ij의 위치를 찾는 것으로 보입니다. arr의 인덱스 ksi와 같을 때, pis 값을 저장하고, j와 같을 때에는 pjs 값을 저장합니다.
즉, ij가 같은 값일 때에만 해당 위치의 인덱스를 pipj에 저장하는 조건으로 작성되었습니다.
이 코드를 통해 arr에서 ij의 위치를 확인할 수 있을 것입니다.
이해에 도움이 되었는지 확인 부탁드립니다. 감사합니다!

안녕하세요. 바뀐 채점사이트 관련해서 문의드립니다.

0

28

1

갑자기 채점 사이트가 바뀌었어요

0

32

1

문제 리스트 페이지

0

29

1

채점 사이트 관련 질문드립니다

0

23

1

봉우리 문제 질문입니다

0

81

2

씨름 선수 문제에서 각 선수의 몸무게나 키가 같을 수도 있다면?

0

64

0

이 코드랑 영상 코드중에 뭐가 더 좋은 코드인가요?

0

72

0

가중치 방향 그래프에서 가중치가 0인 간선을 표현하는 방법

0

67

1

좌표 정렬 문제 이 코드가 왜 틀린지 모르겠습니다 ㅠㅠ

0

85

2

6-7 강의에서

0

48

1

6-6. 장난꾸러기 질문 있습니다.

0

45

1

강의 수강후 코딩테스트

0

110

1

answer 변수 사용 여부

0

45

1

2중 for문

1

85

2

2-11. 임시반장정하기 (Runtime Error)

0

63

1

혹시 LinkedList 같은 자료 구조들은 따로 배우지 않나요?

0

70

1

이런 풀이는 어떨까요

0

44

1

자바 스트림 방식의 효율성 질문 드립니다.

0

57

1

알고리즘 자료 구조들..

0

62

1

StringBuilder vs BufferdWriter

0

48

1

원더랜드(프림)

0

50

1

이런 코드는 어떤가요?

0

61

1

bfs 풀이

0

57

1

병합정렬

0

56

1