๋ณธ๋ฌธ ๋ฐ”๋กœ๊ฐ€๊ธฐ
Algorithm

[๋ฐฑ์ค€] 1748๋ฒˆ: ์ˆ˜ ์ด์–ด ์“ฐ๊ธฐ 1(๊ตฌํ˜„)

by ์ฃผ๋ฐœ2 2020. 3. 5.
๋ฐ˜์‘ํ˜•

https://www.acmicpc.net/problem/1748

 

1748๋ฒˆ: ์ˆ˜ ์ด์–ด ์“ฐ๊ธฐ 1

์ฒซ์งธ ์ค„์— N(1≤N≤100,000,000)์ด ์ฃผ์–ด์ง„๋‹ค.

www.acmicpc.net

์ฝ”๋“œ

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

public class Main {

	public static void main(String[] args) throws IOException {
		BufferedReader bf = new BufferedReader(new InputStreamReader(System.in));
		int count = 0;	// ์ž๋ฆฟ์ˆ˜
		int plus = 1;	// ์ž๋ฆฟ์ˆ˜์— ๋”ํ•˜๋Š” ๊ฐ’
		int num = 10;	// ๋ช‡ ์ž๋ฆฟ์ˆ˜ ๋”ํ• ์ง€ ํŒ๋‹จ
		int N = Integer.parseInt(bf.readLine());
		for(int i=1; i<=N; i++) {
			// ์ž๋ฆฟ์ˆ˜ ๋ฐ”๋€Œ๋Š” ์กฐ๊ฑด => 10, 100, 1000, 10000, ...
			if(i%num == 0) {
				plus ++;
				num *= 10;
			}
			count += plus;

		}
		System.out.println(count);
		bf.close();
	}

}

ํ’€์ด

์ž๋ฆฟ์ˆ˜๋งŒ ๊ตฌํ•˜๋ฉด ๋˜๋ฏ€๋กœ, ์ž๋ฆฟ์ˆ˜๊ฐ€ ์–ธ์ œ ๋ฐ”๋€Œ๋Š”์ง€๋งŒ ํ™•์ธํ•ด์„œ ๋ณ€๊ฒฝํ•ด์ค€๋‹ค.

1 ~ 9 => 1์ž๋ฆฌ

10 ~ 99 => 2์ž๋ฆฌ

100 ~ 999 => 3์ž๋ฆฌ,

์ฆ‰ i๋ฅผ 10 , 100 , ... ์œผ๋กœ ๋‚˜๋ˆด์„๋•Œ ๋ชซ์ด 0์ด๋ฉด ์ž๋ฆฟ์ˆ˜๊ฐ€ ๋ฐ”๋€๋‹ค.

๋”ฐ๋ผ์„œ ์ž๋ฆฟ์ˆ˜๊ฐ€ ๋ฐ”๋€”๋•Œ๋งˆ๋‹ค ๋‹ค์Œ ๋‚˜๋ˆ ์•ผ ํ•˜๋Š” ์ˆ˜๋Š” 10์„ ๊ณฑํ•ด์ฃผ๊ณ ,

๋‹ค์Œ ๋”ํ•ด์ค˜์•ผ ํ•  ์ž๋ฆฟ์ˆ˜๋Š” +1์„ ํ•ด์ค€๋‹ค.

 

๋ฐ˜์‘ํ˜•

๋Œ“๊ธ€