From d851a427afc0b89c61f1bf024c426cb6e6e9f211 Mon Sep 17 00:00:00 2001 From: Jonghwan Lee <123362165+0224LJH@users.noreply.github.com> Date: Sun, 13 Jul 2025 23:05:05 +0900 Subject: [PATCH] =?UTF-8?q?[20250713]=20BOJ=20/=20G1=20/=20=EC=A0=9C?= =?UTF-8?q?=EA=B3=B1=20=E3=84=B4=E3=84=B4=20=EC=88=98=20/=20=EC=9D=B4?= =?UTF-8?q?=EC=A2=85=ED=99=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ... \343\204\264\343\204\264 \354\210\230.md" | 68 +++++++++++++++++++ 1 file changed, 68 insertions(+) create mode 100644 "0224LJH/202507/13 BOJ \354\240\234\352\263\261 \343\204\264\343\204\264 \354\210\230.md" diff --git "a/0224LJH/202507/13 BOJ \354\240\234\352\263\261 \343\204\264\343\204\264 \354\210\230.md" "b/0224LJH/202507/13 BOJ \354\240\234\352\263\261 \343\204\264\343\204\264 \354\210\230.md" new file mode 100644 index 00000000..39677529 --- /dev/null +++ "b/0224LJH/202507/13 BOJ \354\240\234\352\263\261 \343\204\264\343\204\264 \354\210\230.md" @@ -0,0 +1,68 @@ +```java + +import java.io.BufferedReader; +import java.io.IOException; +import java.io.InputStreamReader; +import java.util.Arrays; +import java.util.StringTokenizer; + +public class Main { + static long ans,max,min; + static int len; + static boolean[] powerNoNoNum; + + public static void main(String[] args) throws IOException { + init(); + process(); + print(); + } + + private static void init() throws IOException { + BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); + StringTokenizer st = new StringTokenizer(br.readLine()); + min = Long.parseLong(st.nextToken()); + max = Long.parseLong(st.nextToken()); + len = (int) (max - min+1); + + powerNoNoNum = new boolean[len]; + Arrays.fill(powerNoNoNum,true); + ans = 0; + + } + + private static void process() { + for (long i = 2; i * i <= max; i++){ + long powerNum = i * i; + if (powerNum > max) break; + + long curIdx; + if (powerNum < min) { + long temp = (min + powerNum - 1) / powerNum; + curIdx = temp * powerNum - min; + } else { + curIdx = powerNum - min; + } + + while(curIdx < len){ + powerNoNoNum[(int) curIdx] = false; + curIdx += powerNum; + } + } + + for (int i = 0; i < powerNoNoNum.length; i++){ + if (powerNoNoNum[i]) ans++; + } + } + + + + + private static void print() { + System.out.println(ans); + } + + + +} + +``` \ No newline at end of file