任选4个不完全相同的数字(像1111就不行),让“最大排列”减“最小排列”(例如8753-3578),不断重复这个动作,最后一定会得到相同的结果:6174。神奇的是:这个“最大减最小”的动作,最多不会超过7次! 我们先来看看五组实验结果 请输入一个互不相同的四位数:3758输入的四位数是:3758$ b' E7 _# b" H* p 第1次:8753 - 3578 = 5175 第2次:7551 - 1557 = 5994 第3次:9954 - 4599 = 5355 第4次:5553 - 3555 = 1998 第5次:9981 - 1899 = 80821 S" J( u: e4 e/ A 第6次:8820 - 288 = 8532+ K9 q8 w6 D" N# v! v9 e 第7次:8532 - 2358 = 6174/ S4 ?" B- W& d5 v5 f5 O6 t 经过了7次最大减最小的动作 请输入一个互不相同的四位数:2517 v& L. R) H2 W. I5 y" f 输入的四位数是:2517 第1次:7521 - 1257 = 6264 第2次:6642 - 2466 = 4176 第3次:7641 - 1467 = 6174+ [) A1 b; G( J! \8 h: _: d% d 经过了3次最大减最小的动作 请输入一个互不相同的四位数:6915 输入的四位数是:6915 第1次:9651 - 1569 = 8082 第2次:8820 - 288 = 8532 第3次:8532 - 2358 = 6174+ N% y: i: {) g, G 经过了3次最大减最小的动作) T% f. x0 i3 B% b+ c Z P 请输入一个互不相同的四位数:9073 输入的四位数是:9073 第1次:9730 - 379 = 9351% X# g% i, t, A1 w 第2次:9531 - 1359 = 8172 第3次:8721 - 1278 = 7443 第4次:7443 - 3447 = 3996 第5次:9963 - 3699 = 6264$ K; b/ p0 @6 u3 B2 Q 第6次:6642 - 2466 = 4176 第7次:7641 - 1467 = 6174 经过了7次最大减最小的动作 请输入一个互不相同的四位数:5287 输入的四位数是:52876 ]. Y+ S! C4 ^6 ~ 第1次:8752 - 2578 = 6174 经过了1次最大减最小的动作* i5 m# @/ d& y# Q$ _5 [2 ], \" X1 c 接下来我们用C语言代码进行验证,代码实现如下。 代码实现#include <stdio.h>" D) c3 J5 n8 T6 f$ kint convert(int number[],int ans); int *sort(int number[],int len);6 d+ U7 n3 A4 I0 u8 R int main(void) {& }7 h' }: ]( y5 L int number[4] = {0}; int *p = NULL; int n = 0;9 Q# M! X4 |$ J" D4 m; q int ans = 0;& M2 z& Y" L4 R; S4 g8 v int count = 0;/ x3 w# d; |- n5 N printf("请输入一个互不相同的四位数:");$ \: _; B5 ^7 Y, C5 A' U scanf("%d",&n);. m# S5 {1 j8 @* q( ^ printf("输入的四位数是:%d\n",n);& `& I" [: N/ o% Y ans = n;. N4 ~2 ]* `3 N9 r while(ans!=6174) { ans = convert(number,ans);' U4 [; p# T: I printf("第%d次:%d\n",count+1,ans);, z0 q. b7 s5 T! B" z& q3 H ++count; }0 k$ w; {4 [$ i7 Z, c printf("经过了%d次最大减最小的动作\n",count); return 0;- G2 t( l9 T( D" j5 F1 `5 l }9 V4 W3 U& i9 X ( r$ I- k$ K; U: _* ^) x8 ? int *sort(int number[],int len) //大到小的排序; T8 C6 j: b$ T7 L/ s u( i* I& t { int a =0; for(int i=0; i<len; ++i), S t, M1 ` [; ], m { for(int j=i+1;j<len;++j)# x( P6 Y6 N' t+ G7 i {1 Z- ^# ~7 E, `$ |8 g: ]) g6 T2 ~ if(number <number[j]) {& A& c8 i5 a7 I* w3 ~1 ? a = number;5 d# a: K/ T9 w7 I& n' l number = number[j];2 i0 Y% T2 b' v& Z number[j] = a;; g% {! T* l' Y4 D! v3 E2 U+ O }/ K u2 K+ ~+ F }6 }) R: p# n! d } return number;6 y6 k! @& Q! h7 V/ u" I) w! n } int convert(int number[],int ans)//每次变换得到的数字 { int *p = NULL;7 z' p* L) E @ int m=0; number[0] = ans/1000; //把这个数放入数组 number[1] = ans%1000/100; number[2] = ans%100/10; number[3] = ans%10;; F4 y: p1 m" y0 V7 A f) Y& J p = sort(number,4);; J( C3 d9 G3 p, z- A m=(*p*1000+*(p+1)*100+*(p+2)*10+*(p+3))- ( *(p+3)*1000+*(p+2)*100+*(p+1)*10+*p);//最大数字减去最小数字 return m;! b, x. |1 `9 d. u }, |' ~8 ?$ P: N! y: H: S! {7 c 运行结果: 0 U% t0 h5 s: w" y8 A |
这是什么原理? |
UDS诊断服务
最全USB HID开发资料,悉心整理一个月,亲自测试
刘氓兔的杂谈【001】-片上USB 高速PHY
【经验分享】在进行 USB CDC 类开发时,无法发送 64整数倍的数据
【源码】STLINK-V3MINI 高速USB仿真器,成功改刷【高速CMSIS-DAP】
在线直播|无需编写任何代码即可在STM32上实现USB-C Power Delivery
STM32 USB CDC 虚拟多串口
圈圈发布USB图书第二版有感,以及分享一些我学习USB过程...
USB Audio设计与实现
【MCU实战经验】+STM32F107的USB使用