티스토리 뷰
N=int(input())
res = 0
s = len(str(N))
if s == 1:
res = N
else:
for i in range(2,s+1):
res += (9*(10**(i-2))*(i-1))
res += (N-(10**(s-1)-1))*s
print(res)
한 자리 수 일 때는 받아온 N그대로이니까 N출력
한자리수 이외에는 만약 3자리수이라면 한자리수 * 9개, 두 자리수* 90개를 모두 더해준뒤
N-99(두자리수중 가장 큰것)을 하면 세자리수의 갯수가 나온다.
그래서 그 갯수에 *3을 한 것을 더해줘서 출력했다.
'알고리즘 > 백준' 카테고리의 다른 글
[백준] 2798.블랙잭 - 파이썬 (0) | 2021.08.26 |
---|---|
[백준] 10872. 팩토리얼 - 파이썬 (0) | 2021.08.25 |
[백준] 1476. 날짜 계산 - 파이썬 (0) | 2021.08.01 |
[백준] 2309.일곱난쟁이 - 파이썬 (0) | 2021.07.30 |
[백준] 1541. 잃어버린 괄호 - 파이썬 (0) | 2021.07.17 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- commit되돌리기
- 비동기패턴
- N과M
- 싸피
- SQL
- 자바
- SWEA
- Java
- 독학
- 트리
- 위클리챌린지2주차
- 세션 스토리지
- django
- Pyhton
- 백준
- 안드로이드스튜디오
- javascript
- vue
- 알고리즘
- splide
- 배포
- 파이썬
- Python
- git
- SSAFY퇴소
- vue.js
- SSAFY
- 프로그래머스
- DOM
- AWS
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 29 | 30 |
글 보관함