인프런 커뮤니티 질문&답변

lular_님의 프로필 이미지
lular_

작성한 질문수

[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part1: C# 기초 프로그래밍 입문

연습 문제

겟인덱스를 foreach가 아니라 for로 구현 한 이유가 뭔가요?

해결된 질문

작성

·

417

0

사소한 질문이긴 한데... 애당초 인덱스를 반환하는게 목표니까 굳이 foreach를 사용하지 않는다고 하셨는데 이유가 뭔가요?

차이를 잘 모르겠어요.

답변 3

3

Rookiss님의 프로필 이미지
Rookiss
지식공유자

안녕하세요 ㅎㅎ

GetIndexOf의 요구 기능을 잘못 이해하신 것 같네요.
GetIndexOf는 [value라는 데이터가 scores라는 배열의 몇 번째에 위치해 있는지 (없으면 -1)] 반환하는 기능입니다.
위에 작업하신 코드에서 value를 찾았을 경우return value로  반환을 하셨는데,
그건 어디까지나 value라는 값 자체를 반환한거지,
[몇 번째] 데이터인지에 해당하는 정보가 아닙니다!

감사합니다.

2

Rookiss님의 프로필 이미지
Rookiss
지식공유자

안녕하세요,

for이나 foreach나 결과가 똑같으면 장땡이고
특별히 어떤 쪽을 선택한다고 문제가 되진 않습니다.

다만, 일반적으로 가독성 측면에서

for (int i = 0; i < len; i++)
{
    int score = scores[i];
}

보다는

foreach (int score in scores)

형태가 더 보기 좋긴 하죠!

따라서 예제에서 대부분의 기능들을 foreach로 만들었지만,
예외적으로 Index를 반환하는 함수는 [몇번째 데이터인지]를 반환해야 합니다.
만약 foreach를 사용했다고 치면, 다음과 같이 구현해야 합니다.

int index = -1;
foreach (int s in scores)
{
   index++;
   if (s == value)
       return index;
}

근데 어차피 이렇게 foreach 안에서 또 카운팅을 할거라면,
그냥 for (int i = 0; i < len; i++)을 이용하는게 속이 편하니 for문을 이용하겠하다는 의미였습니다.

0

lular_님의 프로필 이미지
lular_
질문자

빠른 답변 감사합니다 ㅎㅎ

static int GetIndexOf(int[] scores, int value)

{

foreach ( int score in scores)

{

if(value == score)

return value;

}

return -1;

}

처음 숙제 풀 때 이렇게 만들었는데 

이러면 i 값으로 몇 번째 인덱스인지 쉽게 찾을 수 없어서 언젠간 곤란해질 거란 말씀이시죠?

그러니까 인덱스류는 for문이 좋다... 맞나요? 제대로 이해한 건지 모르겠네요 ㅋㅋㅠ

lular_님의 프로필 이미지
lular_

작성한 질문수

질문하기