31.4. 개수(COUNT) 구하기

  • 10 minutes to read

31.4.1. 개수(COUNT; 건수, 카운트) 알고리즘

개수(COUNT) 알고리즘은 조건에 맞는 자료의 개수(횟수, 건수)를 구하는 알고리즘입니다. 다른 표현 방식으로 조건에 맞는 레코드의 횟수를 구하는 데 사용되는 구문입니다.

31.4.2. [실습] 개수(COUNT) 알고리즘 사용하기

주어진 범위의 데이터 중 주어진 조건을 만족하는 데이터의 개수를 구하는 COUNT 알고리즘을 적용해보는 예제를 만들어 봅시다.

*** 예제: 1부터 1,000까지의 정수 중 13의 배수의 개수***

코드: CountAlgorithm.cs

//[?] 1부터 1,000까지의 정수 중 13의 배수의 개수(건수, 횟수)
using System;
using System.Linq;

/// <summary>
/// 개수 알고리즘(Count Algorithm): 주어진 범위에 주어진 조건에 해당하는 자료들의 개수 
/// </summary>
class CountAlgorithm
{
    static void Main()
    {
        //[1] Input: 1부터 1,000까지의 데이터 
        var numbers = Enumerable.Range(1, 1_000).ToArray();
        int count = default; // 개수를 저장할 변수는 0으로 초기화

        //[2] Process: 개수 알고리즘 영역: 주어진 범위에 주어진 조건(필터링)
        for (int i = 0; i < numbers.Length; i++)
        {
            if (numbers[i] % 13 == 0)
            {
                //count = count + 1;
                //count += 1;
                count++; // COUNT
            }
        }

        //[3] Output
        Console.WriteLine($"1부터 1,000까지의 정수 중 13의 배수의 개수: {count}");
    }
}
1부터 1,000까지의 정수 중 13의 배수의 개수: 76

개수 알고리즘은 간단히 증감 연산자를 사용하여 카운트를 세는 방법으로 구할 수 있습니다. 카운트 알고리즘도 LINQ를 사용하면 다음처럼 간단히 표현할 수 있습니다.

> Enumerable.Range(1, 1000).Where(n => n % 13 == 0).Count()
76
> Enumerable.Range(1, 1000).Count(n => n % 13 == 0)
76
VisualAcademy Docs의 모든 콘텐츠, 이미지, 동영상의 저작권은 박용준에게 있습니다. 저작권법에 의해 보호를 받는 저작물이므로 무단 전재와 복제를 금합니다. 사이트의 콘텐츠를 복제하여 블로그, 웹사이트 등에 게시할 수 없습니다. 단, 링크와 SNS 공유, Youtube 동영상 공유는 허용합니다. www.VisualAcademy.com
박용준 강사의 모든 동영상 강의는 데브렉에서 독점으로 제공됩니다. www.devlec.com