백준(S3) 1748번: 수 이어 쓰기 1 (C언어 C11 C99)

2021. 10. 6. 22:48·C언어/백준 문제풀이
반응형

코드를 보기 전에: 이 문제는 브루트포스 알고리즘인것같기도 하고, 동적계획법 알고리즘인것같기도 하다.

이 문제를 단순하게 풀었다면 대부분 시간초과가 나왔을 것이다. 컴퓨터는 1초에 1억번의 계산을 할수 있는데,

이 문제에서는 입력의 값이 1억까지 이기때문이다.

 

공식: 주어진 값 - a + 1을 하면, a (예를들어 100 이면)  세자리 수의 자리수 값을 더한 값이 나온다.

 

Fullcode

1
2
3
4
5
6
7
8
9
10
11
12
#include <stdio.h>
int main()
{
    int num;
    long long result = 0;
    scanf("%d", &num);
    for (int a = 1; a <= num; a *= 10) // 입력된 값에서 1의 자리는 num만큼 있고, 10의 자리는 num-9 (10은 포함하기 때문) 만큼 있어서, A곱하기 10을 했다.
    {
        result += num - a + 1; // 입력된값 - a +1일때 a가 10이면 2자리 숫자를 구하는 것이고, a가 100이면 세자리 숫자의 자리수를 더하는 것이다.
    }
    printf("%lld", result);
}
Colored by Color Scripter
cs

 

반응형
'C언어/백준 문제풀이' 카테고리의 다른 글
  • 백준(S5) 7568번: 덩치 (C언어 C11 C99)
  • 백준(B2) 2231번: 분해합 (C언어 C11 C99)
  • 백준(S5) 1476번: 날짜 계산 (C언어 C11 C99)
  • 백준(S3) 1463번: 1로 만들기 (C 언어 C11 C99)
코딩하는_대학생
코딩하는_대학생
Java Developer, Open Source Enthusiast, Proud Son
  • 코딩하는_대학생
    코딩하는 대학생에서 개발자까지
    코딩하는_대학생
  • 전체
    오늘
    어제
    • 분류 전체보기 (218)
      • 코딩하는 대학생의 책 추천 (8)
        • 클린코드 (5)
        • 헤드퍼스트 디자인패턴 (3)
      • Backend (8)
        • Spring (14)
        • AWS (3)
        • 회고 (4)
        • Redis (5)
        • 다양한 시각에서 바라본 백엔드 (3)
      • Python (35)
        • 개념 및 정리 (15)
        • 백준 문제풀이 (20)
      • JAVA (17)
        • 개념 및 정리 (14)
        • 백준 문제풀이 (2)
      • 왜? (7)
      • C언어 (42)
        • 개념 및 정리 (9)
        • 백준 문제풀이 (32)
      • 개인 공부 (27)
        • 대학 수학 (5)
        • 대학 영어 (10)
        • 시계열데이터 처리 및 분석 (5)
        • 컴퓨터 네트워크 (6)
        • 운영체제 (1)
      • 솔직 리뷰 (23)
        • 꿀팁 (6)
        • IT기기 (1)
        • 국내 여행 (7)
        • 맛집 (2)
        • 알바 리뷰 (2)
      • 대외활동 (17)
        • 체리피우미 3기 (4)
        • 꿀잠이들 6기 (13)
      • 음식 평가 (1)
      • 일상 & 근황 (2)
  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
코딩하는_대학생
백준(S3) 1748번: 수 이어 쓰기 1 (C언어 C11 C99)
상단으로

티스토리툴바