코딩테스트

C# 알고리즘 - 가까운 1 찾기

작성자 정보

  • 마스터 작성
  • 작성일

컨텐츠 정보

본문

 

[문제 설명]

정수 배열 arr가 주어집니다. 이때 arr의 원소는 1 또는 0입니다. 정수 idx가 주어졌을 때, idx보다 크면서 배열의 값이 1인 가장 작은 인덱스를 찾아서 반환하는 solution 함수를 완성해 주세요.


단, 만약 그러한 인덱스가 없다면 -1을 반환합니다. 

 

[제한사항]

3 ≤ arr의 길이 ≤ 100'000

arr의 원소는 전부 1 또는 0입니다. 

 

[입출력 예]

 

[입출력 예 설명]

입출력 예 #1

1보다 크면서 원소가 1인 가장 작은 인덱스는 3입니다. 따라서 3을 return 합니다.

 

입출력 예 #2

4번 인덱스 이후에 1은 등장하지 않습니다. 따라서 -1을 return 합니다.

 

입출력 예 #3

3번 인덱스의 값이 1입니다. 따라서 3을 return 합니다.


 

[코드]

using System;


public class Solution {

    public int solution(int[] arr, int idx) {

        int answer = 0;

        for(int i =idx; i<arr.Length; i++)

        {

            if(arr[i] == 1)

            {

                return answer = i;

            }

            else

            {

                answer = -1;

            }

        }

        return answer;

    }

}

 

[풀이]

1.for문 돌리기 i는 idx부터 

for(int i =idx; i<arr.Length; i++)

 

2.arr[i]의 값이 1이면 해당 index값을 반환 아닐경우 -1

if(arr[i] == 1) return answer = i;

else answer = -1;

 

 

[주소]

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

해당 알고리즘 문제는 프로그래머스의 알고리즘 문제입니다.

관련자료

댓글 0
등록된 댓글이 없습니다.

최근글


새댓글


알림 0