https://www.acmicpc.net/problem/4673
λ¬Έμ
μ ν λλ²λ 1949λ μΈλ μνμ D.R. Kaprekarκ° μ΄λ¦ λΆμλ€. μμ μ μ nμ λν΄μ d(n)μ nκ³Ό nμ κ° μ리μλ₯Ό λνλ ν¨μλΌκ³ μ μνμ. μλ₯Ό λ€μ΄, d(75) = 75+7+5 = 87μ΄λ€.
μμ μ μ nμ΄ μ£Όμ΄μ‘μ λ, μ΄ μλ₯Ό μμν΄μ n, d(n), d(d(n)), d(d(d(n))), ...κ³Ό κ°μ 무ν μμ΄μ λ§λ€ μ μλ€.
μλ₯Ό λ€μ΄, 33μΌλ‘ μμνλ€λ©΄ λ€μ μλ 33 + 3 + 3 = 39μ΄κ³ , κ·Έ λ€μ μλ 39 + 3 + 9 = 51, λ€μ μλ 51 + 5 + 1 = 57μ΄λ€. μ΄λ°μμΌλ‘ λ€μκ³Ό κ°μ μμ΄μ λ§λ€ μ μλ€.
33, 39, 51, 57, 69, 84, 96, 111, 114, 120, 123, 129, 141, ...
nμ d(n)μ μμ±μλΌκ³ νλ€. μμ μμ΄μμ 33μ 39μ μμ±μμ΄κ³ , 39λ 51μ μμ±μ, 51μ 57μ μμ±μμ΄λ€. μμ±μκ° ν κ°λ³΄λ€ λ§μ κ²½μ°λ μλ€. μλ₯Ό λ€μ΄, 101μ μμ±μκ° 2κ°(91κ³Ό 100) μλ€.
μμ±μκ° μλ μ«μλ₯Ό μ ν λλ²λΌκ³ νλ€. 100λ³΄λ€ μμ μ ν λλ²λ μ΄ 13κ°κ° μλ€. 1, 3, 5, 7, 9, 20, 31, 42, 53, 64, 75, 86, 97
10000λ³΄λ€ μκ±°λ κ°μ μ ν λλ²λ₯Ό ν μ€μ νλμ© μΆλ ₯νλ νλ‘κ·Έλ¨μ μμ±νμμ€.
μ λ ₯
μ λ ₯μ μλ€.
μΆλ ₯
10,000λ³΄λ€ μκ±°λ κ°μ μ ν λλ²λ₯Ό ν μ€μ νλμ© μ¦κ°νλ μμλ‘ μΆλ ₯νλ€.
νμ΄
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int d (int n){
int tmp = 0, divisor = 10, sum = 0;
vector <int> v;
//μ£Όμ΄μ§ μ μ nμ κ° μ리μ«μλ€μ vμ λ£λλ€
while(true){
tmp = n % divisor;
if(tmp == n){
v.push_back(tmp / (divisor/10));
divisor *= 10;
break;
}
v.push_back(tmp / (divisor/10));
divisor *= 10;
}
//κ° μ리μ«μλ€μ ν© sum
for(int i=0; i<v.size(); i++){
sum += v[i];
}
return sum + n;
}
int main() {
vector <int> value;
//λ²‘ν° valueμμ 1λΆν° 10000κΉμ§ μλ€μ dκ°λ€ μ μ₯
for(int i=1; i<10001; i++){
value.push_back(d(i));
}
for(int i=1; i<10001; i++){
//valueμ iκ° μλ€λ©΄ i μΆλ ₯
if(find(value.begin(), value.end(), i) == value.end()){
cout << i << "\n";
}
}
return 0;
}
+)
μ£Όμ΄μ§ μ«μμ κ° μ리 μ«μλ
μμ ꡬνλ κ²κ³Ό κ°μ λ°©λ²μΌλ‘ ꡬνλ€
++)
while(num>0) {
sum = num % 10
num /= 10
}
ν¨μ¬ μ¬μ΄ μ½λκ° μμλ€..
'π Cpp > [BOJ] λ¨κ³λ³λ‘ νμ΄λ³΄κΈ°' μΉ΄ν κ³ λ¦¬μ λ€λ₯Έ κΈ
[BOJ][C++] λ°±μ€ 11654λ²: μμ€ν€ μ½λ (0) | 2021.09.09 |
---|---|
[BOJ][C++] λ°±μ€ 1065λ²: νμ (0) | 2021.09.06 |
[BOJ][C++] λ°±μ€ 15596λ²: μ μ Nκ°μ ν© (0) | 2021.09.02 |
[C++][BOJ] λ°±μ€ 4344λ²: νκ· μ λκ² μ§ (0) | 2021.09.02 |
[C++][BOJ] λ°±μ€ 8959λ²: OXν΄μ¦ (0) | 2021.08.21 |