- Today
- Total
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 |
Tags
- 정렬
- 연결리스트
- oauth
- 구글 로그인
- sql
- 백준
- 코딩테스트
- Java
- firebase google
- 안드로이드
- 로그인
- 컴퓨터공학과
- python
- android studio
- 파이썬
- C언어
- 프로그래머스
- 공유대학
- C++
- 안드로이드 스튜디오
- 프로그래밍 입문
- til
- Firebase
- 자료구조
- 자바
- 배열
- 비주얼 베이직
- 동적할당
- 알고리즘
Archives
코딩하는 해달이
[백 준 Java] 1016번 문제 : 제곱 ㄴㄴ수 본문
문제 설명
어떤 정수 X가 1보다 큰 제곱수로 나누어 떨어지지 않을 때, 그 수를 제곱ㄴㄴ수라고 한다. 제곱수는 정수의 제곱이다. min과 max가 주어지면, min보다 크거나 같고, max보다 작거나 같은 제곱ㄴㄴ수가 몇 개 있는지 출력한다.
입력
첫째 줄에 두 정수 min과 max가 주어진다.
출력
첫째 줄에 min보다 크거나 같고, max보다 작거나 같은 제곱ㄴㄴ수의 개수를 출력한다.
제한
- 1 ≤ min ≤ 1,000,000,000,000
- min ≤ max ≤ min + 1,000,000
알고리즘
푼 방법
에라토스테네스의 체를 응용해서 접근했다.
에라토스테네스의 체는 여기서 설명해놓았다.
https://coreeny.tistory.com/36
[알고리즘] 에라토스테네스의 체
알고리즘 초기 sieve 배열의 모든 값은 0으로 초기화되어 있습니다. 2부터 차례대로 정수를 살펴 봅니다. 2가 소수입니다. 따라서, 2의 배수들은 sieve[x] = 1로 전부 표시해 놓습니다. 이럴 경우 sieve[4
coreeny.tistory.com
풀이코드
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer tokenizer = new StringTokenizer(reader.readLine());
long min = Long.parseLong(tokenizer.nextToken());
long max = Long.parseLong(tokenizer.nextToken());
boolean[] isPower = new boolean[(int) (max - min + 1)];
int count = 0;
for (long i = 2; i * i <= max; i++) {
long mini = min / (i * i);
if (mini * i * i < min) {
mini++;
}
for (long j = mini; i * i * j <= max; j++) {
isPower[(int)(i * i * j - min)] = true;
}
}
for (boolean e : isPower) {
if (!e) {
count++;
}
}
System.out.println(count);
}
}
링크
https://www.acmicpc.net/problem/1016
1016번: 제곱 ㄴㄴ 수
어떤 정수 X가 1보다 큰 제곱수로 나누어 떨어지지 않을 때, 그 수를 제곱ㄴㄴ수라고 한다. 제곱수는 정수의 제곱이다. min과 max가 주어지면, min보다 크거나 같고, max보다 작거나 같은 제곱ㄴㄴ수
www.acmicpc.net
반응형
'개인 공부 > 백준' 카테고리의 다른 글
[백 준 Java] 1026번 문제 : 보물 (0) | 2023.03.03 |
---|---|
[백 준 Java] 1027번 문제 : 고층 건물 (0) | 2023.03.01 |
[백 준 Java] 1085번 문제 : 직사각형에서 탈출 (0) | 2023.02.26 |
[백 준 Java] 1004번 문제 : 어린 왕자 (0) | 2023.02.25 |
[백 준 Java] 1003번 문제 : 피보나치 함수 (0) | 2023.02.24 |
Comments