
任选4个不完全相同的数字(像1111就不行),让“最大排列”减“最小排列”(例如8753-3578),不断重复这个动作,最后一定会得到相同的结果:6174。神奇的是:这个“最大减最小”的动作,最多不会超过7次! 我们先来看看五组实验结果 请输入一个互不相同的四位数:37583 W9 l7 O; Y! e7 D输入的四位数是:37583 k) N" B1 H4 Z! }' L: S. f 第1次:8753 - 3578 = 51751 W6 T8 c2 |: D5 g: I0 ?$ P 第2次:7551 - 1557 = 5994 第3次:9954 - 4599 = 5355 第4次:5553 - 3555 = 1998$ P: z* U9 [2 n7 w 第5次:9981 - 1899 = 8082# t8 \; W a* L; b0 N: |( V2 Q 第6次:8820 - 288 = 8532! P8 a- F# u$ M( y C 第7次:8532 - 2358 = 61741 F3 ~/ ` h7 X; w, O# l* e 经过了7次最大减最小的动作 请输入一个互不相同的四位数:25172 \' @+ @! Q! w: D/ u4 c+ H 输入的四位数是:2517 I0 _, N8 @* T0 s6 y: i 第1次:7521 - 1257 = 6264% }# ]; ^8 h3 M" e) e0 P 第2次:6642 - 2466 = 4176# i7 @2 O% u8 Y. h 第3次:7641 - 1467 = 6174 经过了3次最大减最小的动作 W4 N, \: |; q; N0 {$ J 请输入一个互不相同的四位数:6915- d: ^5 v2 F! t6 M- h 输入的四位数是:6915 第1次:9651 - 1569 = 8082 第2次:8820 - 288 = 8532 第3次:8532 - 2358 = 6174 经过了3次最大减最小的动作 请输入一个互不相同的四位数:9073/ L9 M( E( z1 ?+ u4 @/ V3 e 输入的四位数是:9073 第1次:9730 - 379 = 9351& }% t) ~) q6 D0 H& C; O! O 第2次:9531 - 1359 = 8172$ ~; [& t$ h# O. |* Y: V0 z 第3次:8721 - 1278 = 7443" C; D. g) w' T5 @ 第4次:7443 - 3447 = 3996" O \: }/ A. Q* v# X3 k9 z% P 第5次:9963 - 3699 = 6264 第6次:6642 - 2466 = 41768 i3 }: q4 i. g8 ^% L2 y 第7次:7641 - 1467 = 6174! h1 n1 t4 |' q. [1 z 经过了7次最大减最小的动作 请输入一个互不相同的四位数:52875 R4 r) ~5 F: R: u# ` 输入的四位数是:5287 第1次:8752 - 2578 = 6174 经过了1次最大减最小的动作! d: W2 L" [, h! D3 U$ }4 E 接下来我们用C语言代码进行验证,代码实现如下。 代码实现#include <stdio.h>! L2 Y+ N0 j: H4 \int convert(int number[],int ans);2 M7 i4 G5 c9 f& s' x; U int *sort(int number[],int len); 4 K! B" E" S5 H0 F! m# X int main(void) { int number[4] = {0};% B4 M% D! G4 w% B5 G int *p = NULL; int n = 0;4 O* C7 I/ [& |2 |9 Z' O7 @0 X int ans = 0;2 V: S7 }8 b Z G! `8 z int count = 0;% d8 S; [) t$ c& H printf("请输入一个互不相同的四位数:"); scanf("%d",&n); printf("输入的四位数是:%d\n",n); ans = n;- E4 b2 y% g/ S2 J& M while(ans!=6174)1 N# _4 y6 u8 T, X3 f2 _ { ans = convert(number,ans); printf("第%d次:%d\n",count+1,ans);5 I. R! {6 \& ^* m0 A ++count;, _3 U$ i* o6 |' n: H } printf("经过了%d次最大减最小的动作\n",count); return 0; } int *sort(int number[],int len) //大到小的排序 {! i {3 Q# G* M# d: Z4 }& Y int a =0;$ p5 d' t0 y1 }3 Z for(int i=0; i<len; ++i) { for(int j=i+1;j<len;++j) {& B# T z" H0 U4 j0 X& k1 b+ q if(number <number[j]) {3 \0 \1 K# e _9 L- {" M; N& Q a = number;* O: S2 x. y6 ^/ E3 F N3 @ number = number[j];, _7 a" R* K5 U$ p7 Y3 O$ T: i! ~ number[j] = a;$ n. |. w- |1 ~0 k4 N5 ^' G }; ]/ t" J+ [" ~ ?6 ^/ I0 \ }! K$ r% V, x' H; y5 b/ A }. q r1 N: O0 n$ c0 t$ g5 n* K# {% }( `# j5 _ return number;: J" M, l4 e; o } int convert(int number[],int ans)//每次变换得到的数字 {5 P* \7 L; Q; M- f* r! i int *p = NULL; int m=0;0 m5 x3 L* |: P/ E' s3 ]$ m U* o number[0] = ans/1000; //把这个数放入数组7 G: e- E7 T& o; ?$ B u number[1] = ans%1000/100; number[2] = ans%100/10; number[3] = ans%10;, v+ ~! w) R4 J4 g G- Z p = sort(number,4);4 l$ l) i/ S) Q# A0 k, c m=(*p*1000+*(p+1)*100+*(p+2)*10+*(p+3))- ( *(p+3)*1000+*(p+2)*100+*(p+1)*10+*p);//最大数字减去最小数字 return m; } 运行结果: ![]() |
这是什么原理? |
最全USB HID开发资料,悉心整理一个月,亲自测试
实战经验 | 选择USBX模块生成USB CDC ACM无PD的项目
STM32 USB HID键盘例程
UDS诊断服务
刘氓兔的杂谈【001】-片上USB 高速PHY
【经验分享】在进行 USB CDC 类开发时,无法发送 64整数倍的数据
【源码】STLINK-V3MINI 高速USB仿真器,成功改刷【高速CMSIS-DAP】
在线直播|无需编写任何代码即可在STM32上实现USB-C Power Delivery
STM32 USB CDC 虚拟多串口
圈圈发布USB图书第二版有感,以及分享一些我学习USB过程...