감 ¶
미된 드 다. 로봇 과 때까는 ~~
드 ¶
~cpp
// no10042 - Smith Numbers
#include <stdio.h>
#include <string.h>
#define ArSize 30
int digit_separation(int, int, int*);
void prime_factor(int, int*);
int prime(int); /* : 200, 님 : 100 */
int arr_add(int*);
int main(void)
{
int arr_separation[ArSize] = { 0 }, arr_prime[ArSize] = { 0 };
int arr_separation_prime[ArSize] = { 0 };
int input_number, input_case, i, j, k;
scanf("%d", &input_number);
for (i = 0; i < input_number; i++)
{
scanf("%d", &input_case);
for (j = input_case + 1; j < 1000000000; j++)
{
/* */
if (prime(j) == 100)
{
/* 다 개개 로 리 */
prime_factor(j, arr_prime);
for (k = 0; k < ArSize; k++)
{
// 두 리 때
if (arr_prime[k] >= 10)
k = digit_separation(k, arr_prime[k], arr_separation_prime);
else
arr_separation_prime[k] = arr_prime[k];
}
/* 력값 각 리 배 */
digit_separation(0, j, arr_separation);
/* 력값 값들 과 력값 개개 교*/
if (arr_add(arr_separation_prime) == arr_add(arr_separation))
{
printf("%dn", j);
break;
}
/* 배 기 */
for (i = 0; i < ArSize; i++)
{
arr_separation[i] = 0 ;
arr_prime[i] = 0;
arr_separation_prime[i] = 0;
}
}
}
}
return 0;
}
/* 력 를 나 리 배 */
int digit_separation(int start_index, int num, int *array)
{
/* 력 를 문로 기 */
char string[ArSize];
int i, size;
// int num를 10 로 char string배
sprintf(string, "%d", num);
size = strlen(string);
/* 문로 된 를 드 값 변 array 다. */
for (i = 0 + start_index; i < size + start_index; i++)
array[i] = string[i - start_index] - '0';
return size + start_index;
}
/* 력 */
void prime_factor(int num, int *array)
{
int i, j, temp;
temp = num;
for (i = 2, j = 0; i < num, j < ArSize;)
{
/* 더 것 면 */
if (temp == 1)
break;
/* 가 가능면 */
if (temp % i == 0)
{
/* 배 다. */
array[j] = i;
temp /= i;
j++;
}
else
i++;
continue;
}
}
/* - 면 : return 1, 가 면 : return 2 */
int prime(int num)
{
int i;
for (i = 2; i < num; i++)
{
/* 가 면 */
if (num % i == 0)
return 100;
}
/* 면 */
return 200;
}
/* 배 덧 */
int arr_add(int *array)
{
int i, total = 0;
for (i = 0; i < ArSize; i++)
total += array[i];
return total;
}










