diff --git a/miniron-v/README.md b/miniron-v/README.md index e1e10c4..f8ea8e1 100644 --- a/miniron-v/README.md +++ b/miniron-v/README.md @@ -18,4 +18,5 @@ | 13차시 | 2024.02.06 | DP | [퇴사 2](https://www.acmicpc.net/problem/15486) | [#50](https://github.com/AlgoLeadMe/AlgoLeadMe-5/pull/50) | | 14차시 | 2024.02.11 | 그래프, DP | [ACM Craft](https://www.acmicpc.net/problem/1005) | [#53](https://github.com/AlgoLeadMe/AlgoLeadMe-5/pull/53) | | 15차시 | 2024.02.15 | DP, 큰 수 연산 | [타일링](https://www.acmicpc.net/problem/1793) | [#56](https://github.com/AlgoLeadMe/AlgoLeadMe-5/pull/56) | +| 16차시 | 2024.02.18 | 수학 | [합](https://www.acmicpc.net/problem/1081) | [#61](https://github.com/AlgoLeadMe/AlgoLeadMe-5/pull/61) | --- diff --git "a/miniron-v/\354\210\230\355\225\231/1081-\355\225\251.cpp" "b/miniron-v/\354\210\230\355\225\231/1081-\355\225\251.cpp" new file mode 100644 index 0000000..76daf6a --- /dev/null +++ "b/miniron-v/\354\210\230\355\225\231/1081-\355\225\251.cpp" @@ -0,0 +1,36 @@ +#include + +long long gaussSum(long long k) { + if (k % 2 == 0) { + return (k / 2) * (k + 1); + } + + return ((k + 1) / 2) * k; +} + +long long getSumOfPlace(long long n) { + if (n < 1) { + return 0; + } + + long long answer = gaussSum(n); + + long long d = 10; + while ((n / d) > 0) { + long long q = n / d; + long long r = n % d; + + answer -= 9 * (gaussSum(q - 1) * d + q * (r + 1)); + + d *= 10; + } + + return answer; +} + +int main() { + long long l, u; + std::cin >> l >> u; + + std::cout << getSumOfPlace(u) - getSumOfPlace(l - 1); +} \ No newline at end of file