Official

C - Kaprekar Number Editorial by kyopro_friends


問題文に指示された通りの 33 つの関数を作成し、数列を順に計算していけばよいです。g1g_1 及び g2g_2 の計算は多くの言語では「数値を文字列に変換してからソートし、数値に戻す」とすると容易です。

実装例(Python)

Copy
  1. def g1(n):
  2. return int(''.join(sorted(str(n))[::-1]))
  3. def g2(n):
  4. return int(''.join(sorted(str(n))))
  5. def f(n):
  6. return g1(n)-g2(n)
  7. N,K = map(int,input().split())
  8. for _ in range(K):
  9. N = f(N)
  10. print(N)
def g1(n):
    return int(''.join(sorted(str(n))[::-1]))

def g2(n):
    return int(''.join(sorted(str(n))))

def f(n):
    return g1(n)-g2(n)

N,K = map(int,input().split())
for _ in range(K):
    N = f(N)
print(N)

実装例(C)

Copy
  1. #include<stdio.h>
  2. int f(int n){
  3. int c[20]={};
  4. while(n){
  5. c[n%10]++;
  6. n/=10;
  7. }
  8. int g1=0,g2=0;
  9. for(int i=9;i>=0;i--)for(int j=0;j<c[i];j++)g1=g1*10+i;
  10. for(int i=0;i<=9;i++)for(int j=0;j<c[i];j++)g2=g2*10+i;
  11. return g1-g2;
  12. }
  13. int main(){
  14. int n,k;
  15. scanf("%d%d",&n,&k);
  16. for(int i=0;i<k;i++)n=f(n);
  17. printf("%d\n",n);
  18. }
#include<stdio.h>
int f(int n){
	int c[20]={};
	while(n){
		c[n%10]++;
		n/=10;
	}
	int g1=0,g2=0;
	for(int i=9;i>=0;i--)for(int j=0;j<c[i];j++)g1=g1*10+i;
	for(int i=0;i<=9;i++)for(int j=0;j<c[i];j++)g2=g2*10+i;
	return g1-g2;
}

int main(){
	int n,k;
	scanf("%d%d",&n,&k);
	for(int i=0;i<k;i++)n=f(n);
	printf("%d\n",n);
}

posted:
last update:



2025-04-05 (Sat)
12:52:44 +00:00