请教各位大咖,帮帮忙!
https://www.bccn.net/run/我在这个在线编程里输入代码,代码是网上找到,本人一点都不会的,为什么都运行不起来,谁能指导我一下。
我要那个证明数字黑洞6174的代码,感谢你的帮助!
程序代码:#include<stdio.h>
#include <stdlib.h>
#include <time.h>
#define N 10
#define num_1 8999
void vr6174(int);
void parse_sort(int num,int *each);
void max_min(int *each,int *max,int *min);
void parse_sort(int num,int *each);
int count=0;
void main()
{
int n;
int cou=0,num_max;
srand(time(0)); /*设置种子,并生成伪随机序列*/
for(int i=0;i<N;i++)
{
printf("第%d组数据\n",i+1);
n=rand()%1000;/*生成0~9999随机数*/
if(n<1000)
{
n+=1000;
}
vr6174(n); //调用函数进行验证
if(count>cou)
{
num_max=n;
cou=count;
}
count=0;
}
printf("最大次数:%d,数字是:%d\n",cou,num_max);
}
void vr6174(int num)
{
int each[4],max,min;
if(num!=6174&&num) /*若不等于74且不等于0则进行卡布列克运算*/
{
parse_sort(num,each); /*将整数分解,数字存入each数组中*/
max_min(each,&max,&min); /*求数字组成的最大值和最小值*/
num=max-min; /*求最大值和最小值的差*/
printf("[%d]: %d-%d=%d\n",++count,max,min,num); /*输出该步计算过程*/
vr6174(num); /*递归调用自身继续进行卡布列克运算*/
}
}
void parse_sort(int num,int *each)
{
int i,*j,*k,temp;
for(i=0;i<=4;i++) /*将NUM分解为数字*/
{
j=each+3-i;
*j=num%10;
num/=10;
}
for(i=0;i<3;i++) /*对各保数字从小到大进行排序*/
for(j=each,k=each+1;j<each+3-i;j++,k++)
if(*j>*k) { temp=*j;*j=*k;*k=temp;}
return;
}
void max_min(int *each,int *max,int *min) /*将分解的数字还原为最大整数和最小整数*/
{
int *i;
*min=0;
for(i=each;i<each+4;i++) /*还原为最小的整数*/
*min=*min*10+*i;
*max=0;
for(i=each+3;i>=each;i--) /*还原为最大的整数*/
*max=*max*10+*i;
return;
}
程序代码:#include <stdio.h>
#include <stdlib.h>
int sort_func(const void * a, const void * b) {
return *(int*)a - *(int*)b;
}
int main () {
printf("请输入四位数:");
int n,i;
scanf("%d", &n);// 输入四位数
printf("\n输入的四位数为:%d\n", n);
int prev = 0;// 上一个数
int cur = n; // 当前数
int times = 0;// 次数
int str[4];
printf("times\tprev\tcur");
do {
prev = cur;// 保存上一轮生成的数
i = 3;
// 整理成数组
while(i >= 0) {
str[i--] = cur%10;
cur /= 10;
}
// 按从小到大排序,参数分别为 数组,长度,单位长度,比较规则的自定义函数
qsort(str, 4, sizeof(int), sort_func);
cur = 0;
// 生成新的数更新当前值
for (i = 3; i >= 0; i--) {
cur *= 10;
cur += str[i] - str[3-i];
}
times++;
printf("\n%d:\t%d\t%d", times, prev, cur);
}while (cur != prev);// 当前一个数和后一个重复,跳出循环
return 0;
}

[此贴子已经被作者于2020-2-29 11:29编辑过]