IT/Python Algorithm

[Python Algorithm]

Lindsay 2021. 2. 12. 18:40
728x90

 


1. K번째 큰 수

어떤 자연수 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번째 약수가 존재하지 않을 경우에는 -1을 출력하시오.

 

입력예제 1

6 3

 

출력예제 1

3

import sys
sys.stdin = open("input.txt", "rt")

n, k = map(int, input().split())
cnt=0
for i in range(1, n+1):
	if n%i==0:
		cnt+=1
	if cnt == k:
		print(i)
		break
else:
	print(-1)

 


2. K번째 수

N개의 숫자로 이루어진 숫자열이 주어지면 해당 숫자열중에서 s번째부터 e번째 까지의 수를 오름 차순 정렬했을 때 k번째로 나타나는 숫자를 출력하는 프로그램을 작성하세요.

 

입력설명
첫 번째 줄에 테스트 케이스 T(1<=T<=10)이 주어집니다.


각 케이스별
첫 번째 줄은 자연수 N(5<=N<=500), s, e, k가 차례로 주어진다.

두 번째 줄에 N개의 숫자가 차례로 주어진다.

 

출력설명
각 케이스별 k번째 수를 아래 출력예제와 같이 출력하세요.

 

입력예제 1

2
6 2 5 3

5 2 7 3 8 9

15 3 10 3

4 15 8 16 6 6 17 3 10 11 18 7 14 7 15

 

출력예제 1

#1 7
#2 6

 

입력예제1

해설 :
case 1 : 2 7 3 8의 숫자 중 오름차순 정렬 했을 때 3번째 숫자는 7이다.
case 2 : 8 16 6 6 17 3 10 11의 숫자 중 오름차순 정렬 했을 때 3번째 숫자는 6이다.

 

import sys
sys.stdin = open("input.txt", "rt")

T = int(input())
for t in range(T):
    n, s, e, k = map(int, input().split())
    a = list(map(int, input().split()))
    a=a[s-1:e]
    a.sort()
    print("#%d %d" %(t+1, a[k-1]))

3. K번째 큰 수

현수는 1부터 100사이의 자연수가 적힌 N장의 카드를 가지고 있습니다. 같은 숫자의 카드가 여러장 있을 수 있습니다.

현수는 이 중 3장을 뽑아 각 카드에 적힌 수를 합한 값을 기록하려 고 합니다. 3장을 뽑을 수 있는 모든 경우를 기록합니다.

기록한 값 중 K번째로 큰 수를 출력 하는 프로그램을 작성하세요.

만약 큰 수부터 만들어진 수가 25 25 23 23 22 20 19......이고 K값이 3이라면 K번째 큰 값은 22입니다.

 

입력설명
첫 줄에 자연수 N(3<=N<=100)과 K(1<=K<=50) 입력되고, 그 다음 줄에 N개의 카드값이 입력 된다.

 

출력설명
첫 줄에 K번째 수를 출력합니다. K번째 수는 반드시 존재합니다.

 

입력예제 1
10 3
13 15 34 23 45 65 33 11 26 42

 

출력예제 1

143

import sys
sys.stdin = open("input.txt", "rt")

n, k = map(int, input().split())
a = list(map(int, input().split()))
res=set()
# set이라는 자료구조는 중복을 제거한다.

for i in range(n):
    for j in range(i+1, n):
        for m in range(j+1, n):
            res.add(a[i]+a[j]+a[m])
res=list(res)
res.sort(reverse=True)
print(res[k-1])

4. 최솟값 구하기

 

5. 대표값

 

6. 대표값 오류 수정

 

 

 

 

728x90