문제
어떤 자연수 p와 q가 있을 때, 만일 p를 q로 나누었을 때 나머지가 0이면 q는 p의 약수이다.
6을 예로 들면
- 6 ÷ 1 = 6 … 0
- 6 ÷ 2 = 3 … 0
- 6 ÷ 3 = 2 … 0
- 6 ÷ 4 = 1 … 2
- 6 ÷ 5 = 1 … 1
- 6 ÷ 6 = 1 … 0
그래서 6의 약수는 1, 2, 3, 6, 총 네 개이다.
두 개의 자연수 N과 K가 주어졌을 때, N의 약수들 중 K번째로 작은 수를 출력하는 프로그램을 작성하시오.
입력
첫째 줄에 N과 K가 빈칸을 사이에 두고 주어진다. N은 1 이상 10,000 이하이다. K는 1 이상 N 이하이다.
출력
첫째 줄에 N의 약수들 중 K번째로 작은 수를 출력한다. 만일 N의 약수의 개수가 K개보다 적어서 K번째 약수가 존재하지 않을 경우에는 0을 출력하시오.
풀이 코드
using System;
class Program
{
static void Main(string[] args)
{
var input = Console.ReadLine().Split();
var num1 = Int32.Parse(input[0]);
var num2 = Int32.Parse(input[1]);
Console.WriteLine(divisor(num1, num2));
}
static int divisor(int n, int idx)
{
int index = 0;
for (int i = 1; i <= n; i++)
{
if (n % i == 0)
{
index++;
if (index == idx)
{
return i;
}
}
}
return 0;
}
}
풀이 코드 LINQ 버전
using System;
using System.Collections.Generic;
using System.Linq;
class Program
{
static void Main(string[] args)
{
var input = Console.ReadLine().Split();
var num1 = Int32.Parse(input[0]);
var num2 = Int32.Parse(input[1]);
var result = divisor(num1).Where((x, idx) => idx == num2 - 1);
if (result.Count() == 0)
{
Console.WriteLine("0");
}
else
{
Console.WriteLine(result.First());
}
}
static IEnumerable<int> divisor(int n)
{
for (int i = 1; i <= n; i++)
{
if (n % i == 0)
{
yield return i;
}
}
}
}
'프로그래밍 > Algorithm' 카테고리의 다른 글
순열과 조합 관련 코드 (0) | 2024.03.22 |
---|---|
C# [백준 BAEKJOON] 2981번 검문 (0) | 2024.03.22 |
일반 더하기 곱셈 vs 고대 이집트 곱셈법 (0) | 2024.03.18 |
C# [백준 BAEKJOON] 1182번 부분수열의 합 (0) | 2024.03.18 |
C# [백준 BAEKJOON] 15650번 N과 M (2) (0) | 2024.03.18 |
댓글