<청춘> 격정적으로 사는 것

밤을 새고 공부한 다음 날 새벽에 느꼈던 생생한 환희와 야생적인 즐거움을 잊을 수 없다

전체 글 101

[백준] 11653번: 소인수 분해 / 파이썬

https://www.acmicpc.net/problem/11653 11653번: 소인수분해 첫째 줄에 정수 N (1 ≤ N ≤ 10,000,000)이 주어진다. www.acmicpc.net 소인수 분해란? 자연수를 소수들만의 곱으로 나타내는 것을 소인수 분해라고 한다. 1보다 큰 자연수는 유한개의 소수(소인수)의 곱의 꼴로 나타낼 수 있는데, 이 곱의 꼴을 자연수의 소인수 분해라고 한다. 예) 24의 소인수 분해 24 = 2 x 2 x 2 x 3 = 2^3 x 3 N = 24 일 때의 소인수 분해를 통해 알고리즘을 알아보자. d = 2 (2부터 나누어떨어지는지 확인한다.) 24는 2로 나누어떨어지므로 소인수에 2를 담고, 24는 2로 나눈 12가 된다. N = 12 소인수 = 2 12는 2로 나누어떨어..

[알고리즘] 소수의 판별 / 약수 / 에라토스테네스의 체 / 파이썬

소수 (Prime Number) 2보다 큰 자연수 중에서 1과 자기 자신을 제외한 자연수로는 나누어떨어지지 않는 자연수이다. 단, 1은 소수가 아니다. 예) 6은 1,2,3,6 으로 나누어떨어진다. 따라서 6은 소수가 아니다. 하지만 7은 1과 7을 제외하고는 나누어떨어지지 않는다. 따라서 7은 소수이다. 소수 판별법 가장 먼저 어떠한 수 X가 주어졌을 때 해당 수가 소수인지 아닌지 판별하는 방법에 대해서 살펴보자. 가장 간단한 방법은 X를 2부터 X-1까지의 모든 수로 나누어보는 것이다. 만약 2부터 X-1까지의 모든 자연수로 나누었을 때 나누어떨어지는 수가 하나라도 존재한다면 X는 소수가 아니다. 코드 # 소수 판별 함수 def is_prime_number(x): # 2부터 (x-1)까지의 모든 수를..

[Spring Boot] 스프링 부트 가이드 : 개발환경 준비 / JDK / 인텔리제이(IntelliJ) / project 설정

https://spring.io/projects/spring-boot Spring Boot Get support Spring Runtime offers support and binaries for OpenJDK™, Spring, and Apache Tomcat® in one simple subscription. Learn more spring.io Spring Boot 특징 독립형 Spring 애플리케이션 생성 Tomcat, Jetty 또는 Undertow를 직접 포함(WAR 파일을 배포할 필요 없음) 빌드 구성을 단순화하기 위해 독자적인 '스타터' 종속성을 제공합니다. 가능할 때마다 Spring 및 타사 라이브러리를 자동으로 구성 메트릭, 상태 확인 및 외부 구성과 같은 프로덕션 준비 기능을 제공합니다..

JAVA/Spring Boot 2021.07.27

[알고리즘] 최단 경로 : 특정 지점까지 가장 빠르게 도달하는 방법을 찾는 알고리즘 / 다익스트라(Dijkstra) 알고리즘/ 개선된 다익스트라 알고리즘 / 파이썬

최단 경로 (Shortest Path) 가장 짧은 경로를 찾는 알고리즘 '길 찾기' 문제라고도 불린다. 보통 그래프를 이용해 표현한다. 다익스트라 최단 경로 알고리즘 (Dijkstra) 그래프에서 여러 개의 노드가 있을 때, 특정한 노드에서 출발하여 다른 노드로 가는 각각의 최단 경로를 구해주는 알고리즘이다. 다익스트라 최단 경로 알고리즘은 '음의 간선'이 없을 때 정상적으로 동작한다. 음의 간선이란 0보다 작은 값을 가지는 간선을 의미한다. 원리 다익스트라 최단 경로 알고리즘은 매번 '가장 비용이 적은 노드'를 선택해서 임의의 과정을 반복하기 때문에 기본적으로 그리디 알고리즘으로 구분된다. 출발 노드를 설정한다. 최단 거리 테이블을 초기화한다. 방문하지 않은 노드 중에서 최단 거리가 가장 짧은 노드를 ..

파이썬 Python 2021.07.27

[다이나믹 프로그래밍 / 동적계획법] 실전 문제 <5> 효율적인 화폐 구성 / 이것이 취업을 위한 코딩테스트다 with 파이썬

효율적인 화폐 구성 N가지 종류의 화폐가 있다. 이 화폐들의 개수를 최소한으로 이용해서 그 가치의 합이 M원이 되도록 하려고 한다. 이때 각 화폐는 몇 개라도 사용할 수 있으며, 사용한 화폐의 구성은 같지만 순서만 다른 것은 같은 경우로 구분한다. 예를 들어 2원, 3원 단위의 화폐가 있을 때는 15원을 만들기 위해 3원을 5개 사용하는 것이 가장 최소한의 화폐 개수이다. 입력 조건 첫째 줄에 N, M이 주어진다. (1≤N≤100, 1≤M≤10,000) 이후 N개의 줄에는 각 화폐의 가치가 주어진다. 화폐 가치는 10,000 보다 작거나 같은 자연수이다. 출력 조건 첫째 줄에 M원을 만들기 위한 최소한의 화폐 개수를 출력한다. 불가능할 때는 -1을 출력한다. 입력 예시1 2 15 2 3 출력 예시1 5 ..

코딩테스트 2021.07.26