유클리드 호제법
·
Data structure
방법1 def gcd(num1,num2): if(num1>num2): if(num1%num2==0): return num2 else: return gcd(num2,num1%num2) else: if(num2%num1==0): return num1 else: return gcd(num1,num2%num1) if __name__ == "__main__": num1,num2=map(int,input().split()) print(gcd(num1,num2))
백준 1676번 : 팩토리얼 0의 개수
·
Algorithm/백준
문제 N!에서 뒤에서부터 처음 0이 아닌 숫자가 나올 때까지 0의 개수를 구하는 프로그램을 작성하시오. 입력 첫째 줄에 N이 주어진다. (0 ≤ N ≤ 500) 출력 첫째 줄에 구한 0의 개수를 출력한다. 예제 입력 1 복사 10 예제 출력 1 복사 2 예제 입력 2 복사 3 예제 출력 2 복사 0 코드 def factorial(num): if(num==1 or num==0): return 1 return num*factorial(num-1) if __name__ == "__main__": num=int(input()) chk=0 fac_num=list(str(factorial(num))) for i in range(len(fac_num)-1,0,-1): if(fac_num[i]=='0'): chk+=1..
백준 10872번 : 팩토리얼(python)
·
Algorithm/백준
문제 0보다 크거나 같은 정수 N이 주어진다. 이때, N!을 출력하는 프로그램을 작성하시오. 입력 첫째 줄에 정수 N(0 ≤ N ≤ 12)이 주어진다. 출력 첫째 줄에 N!을 출력한다. 예제 입력 1 복사 10 예제 출력 1 복사 3628800 예제 입력 2 복사 0 예제 출력 2 복사 1 코드 def factorial(num): if(num==1 or num==0): return 1 return num*factorial(num-1) if __name__ == "__main__": num=int(input()) print(factorial(num)) 느낀점 재귀함수를 사용하려면 펼쳤을때 내가 원하는 식이 되어야한다.
에라토스의 체(python)
·
Data structure
방법1 if __name__ == "__main__": #크기는 100이라고 가정 arr=[] for i in range(101): arr.append(i) for i in range(11): if(arr[i]==0 or arr[i]==1): arr[i]=False continue if(arr[i]!=False): for k in range(i+i,101,i): arr[k]=False print(arr) 방법2 if __name__ == "__main__": #100까지의 수에서의 소수 구하기 num=int(input()) decimal=[] chk=False for i in range(2,num): if(i==2): decimal.append(i) else: for k in decimal: if(i%k..
백준 6588번 : 골드바흐의 추측(python)
·
Algorithm/백준
문제 1742년, 독일의 아마추어 수학가 크리스티안 골드바흐는 레온하르트 오일러에게 다음과 같은 추측을 제안하는 편지를 보냈다. 4보다 큰 모든 짝수는 두 홀수 소수의 합으로 나타낼 수 있다. 예를 들어 8은 3 + 5로 나타낼 수 있고, 3과 5는 모두 홀수인 소수이다. 또, 20 = 3 + 17 = 7 + 13, 42 = 5 + 37 = 11 + 31 = 13 + 29 = 19 + 23 이다. 이 추측은 아직도 해결되지 않은 문제이다. 백만 이하의 모든 짝수에 대해서, 이 추측을 검증하는 프로그램을 작성하시오. 입력 입력은 하나 또는 그 이상의 테스트 케이스로 이루어져 있다. 테스트 케이스의 개수는 100,000개를 넘지 않는다. 각 테스트 케이스는 짝수 정수 n 하나로 이루어져 있다. (6 ≤ n ..
백준1978 : 소수찾기(python)
·
Algorithm
문제 주어진 수 N개 중에서 소수가 몇 개인지 찾아서 출력하는 프로그램을 작성하시오. 입력 첫 줄에 수의 개수 N이 주어진다. N은 100이하이다. 다음으로 N개의 수가 주어지는데 수는 1,000 이하의 자연수이다. 출력 주어진 수들 중 소수의 개수를 출력한다. 예제 입력 1 복사 4 1 3 5 7 예제 출력 1 복사 3 코드 #include #include #include int decimal(int num) { int chk=0; if (num == 1) { return 0; } for (int i = 2; i < num; i++) { if (num % i == 0) { chk = 1; } } if (chk == 1) { return 0; } else { return 1; } } int main() ..
백준 1929번 : 소수구하기(python)
·
Algorithm
문제 M이상 N이하의 소수를 모두 출력하는 프로그램을 작성하시오. 입력 첫째 줄에 자연수 M과 N이 빈 칸을 사이에 두고 주어진다. (1 ≤ M ≤ N ≤ 1,000,000) M이상 N이하의 소수가 하나 이상 있는 입력만 주어진다. 출력 한 줄에 하나씩, 증가하는 순서대로 소수를 출력한다. 예제 입력 1 복사 3 16 예제 출력 1 복사 3 5 7 11 13 코드 m,n=map(int,input().split()) num=[] result=[] chk=False for i in range(m,n+1): num.append(i) for i in num: if(i==1): continue elif(i==2): result.append(i) else: for j in range(2,int(i**0.5)+1):..
백준 1934번 : 최소공배수
·
Algorithm
문제 두 자연수 A와 B에 대해서, A의 배수이면서 B의 배수인 자연수를 A와 B의 공배수라고 한다. 이런 공배수 중에서 가장 작은 수를 최소공배수라고 한다. 예를 들어, 6과 15의 공배수는 30, 60, 90등이 있으며, 최소 공배수는 30이다. 두 자연수 A와 B가 주어졌을 때, A와 B의 최소공배수를 구하는 프로그램을 작성하시오. 입력 첫째 줄에 테스트 케이스의 개수 T(1 ≤ T ≤ 1,000)가 주어진다. 둘째 줄부터 T개의 줄에 걸쳐서 A와 B가 주어진다. (1 ≤ A, B ≤ 45,000) 출력 첫째 줄부터 T개의 줄에 A와 B의 최소공배수를 입력받은 순서대로 한 줄에 하나씩 출력한다. 예제 입력 1 복사 3 1 45000 6 10 13 17 예제 출력 1 복사 45000 30 221 코드..