一、4位数的数字黑洞
任意给定一个4位数(不能所有位都相同),比如:3278,重新组合出最大数:8732,再重新组合出最小数:2378,相减,得到新的4位数(如不足则补0),重复这个过程,最后必然得到一个数字:6174。这个现象被称为:数字黑洞。
编写一个程序,验证这个现象。
例如,给出四位数3278,则有验证过程如下:
8732-2378=6354
6543-3456=3087
8730-378=8352
8532-2358=6174
再如,给出四位数1011,则有验证过程如下:
1110-111=999 (不足4位,补0)
9990-999=8991
9981-1899=8082
8820-288=8532
8532-2358=6174
(1)编程思路。
编写函数void parse(int n,int *max,int *min),该函数的功能求出由整数n的四位数字组合成的最大数和最小数,分别通过形参max和min返回。
在函数中,定义一个数组int a[4],用于保存整数n的4位数字,然后将数组a按从小到大的顺序排列,之后各数字顺序组成最小数,逆序组成最大数。
(2)源程序。
#include <stdio.h>
void parse(int n,int *max,int *min)
{
int a[4],i,j,t;
for (i=0; i<4; i++)
{
a[3-i] = n%10;
n/=10;
}
for (i=0; i<3; i++) // 将四个数字按从小到大顺序排列
for (j=0; j<3-i; j++)
if (a[j]>a[j+1])
{
t = a[j+1];
a[j+1] = a[j];
a[j] = t;
}
t=0;
for (i=0; i<4; i++)
t = t * 10 + a[i] ;
*min=t;
t = 0;
for (i=3; i>=0; i--)
t= t * 10 + a[i];
*max=t;
}
int main()
{
int n,max,min;
scanf("%d",&n);
do
{
parse(n,&max,&min);
printf("%d-%d=%d\n",max,min,max-min);
n=max-min;
}while (n!=6174);
return 0;
}
二、5位数的数字黑洞
任意一个5位数,比如:12345,把它的各位数字打乱,重新排列,可以得到一个最大的数:54321,一个最小的数12345。求这两个数字的差,得:41976,把这个数字再次重复上述过程(如果不足5位,则前边补0)。如此往复,数字会落入某个循环圈(称为数字黑洞)。
例如,刚才的数12345会落入:[82962, 75933, 63954, 61974] 这个循环圈。计算过程如下:
54321 - 12345 = 41976
97641 - 14679 = 82962
98622 - 22689 = 75933
97533 - 33579 = 63954
96543 - 34569 = 61974
97641 - 14679 = 82962
[82962,75933,63954,61974]
再如,整数11211会落入:[74943,62964,71973,83952]这个循环圈。计算过程如下:
21111 - 11112 = 9999 (不足5位,则前边补0)
99990 - 9999 = 89991
99981 - 18999 = 80982
98820 - 2889 = 95931
99531 - 13599 = 85932
98532 - 23589 = 74943
97443 - 34479 = 62964
96642 - 24669 = 71973
97731 - 13779 = 83952
98532 - 23589 = 74943
[74943,62964,71973,83952]
还如,整数50000会落入:[53955,59994]这个循环圈。计算过程如下:
50000 - 5 = 49995
99954 - 45999 = 53955
95553 - 35559 = 59994
99954 - 45999 = 53955
[53955,59994]
编写一个程序,找到5位数所有可能的循环圈,并输出,每个循环圈占1行。其中5位数全都相同则循环圈为 [0],这个可以不考虑。循环圈的输出格式仿照:
[82962, 75933, 63954, 61974] 其中数字的先后顺序可以不考虑。
(1)编程思路。
如同上面4位数的数字黑洞,编写函数int next(int n) ,其功能是求5位整数n的各位数字所组成的最大数与最小数的差值,并将求得的差值作为函数值返回。
为了找出一个整数n的循环圈,编写一个函数void heidong(int n),寻找整数n的循环圈。在函数中,定义一个数组int a[20]用于保存计算过程中的每一个差值。
初始时,置a[0]=n,之后用next()函数求得n的各位数字组成的最大数与最小数的差值,保存到a[1]中,即a[1]=next(a[0]),再求 a[2]=next(a[1]),…,a[i]=next(a[i-1])。
每次求得了a[i]后,将a[i]与a[0]~a[i-1]中保存的各数依次比较,若每个a[j]==a[i](0≤j≤i-1),则找到了循环圈 a[j]~a[i-1]。输出这个循环圈。并将这个循环圈中的各个数保存到全局数组b中。
之所以要将循环圈中的数保存到全局数组中,是因为很多5位数会落在同一个循环圈中。例如,整数10000会落在[74943,62964,71973,83952]循环圈中,11112、11121、11211、…这些数同样落在这个循环圈中。这样当计算10000找到了循环圈后,将74943、62964、71973、83952这4个数保存在全局数组b中,当以后计算到11112时,找到了循环圈,由于循环圈中的数74943已在全局数组b中存在,因此这个循环圈是重复的,无需输出。这样,可以用循环
for(i=10000;i<99999;i++)
{
if (next(i)==0) continue; // 各位数字全部相同,忽略
heidong(i);
}
找出所有5位数可能的循环圈。
(2)源程序。
#include<stdio.h>
int b[12]={0}, cnt=0; // 保存各循环圈中的数避免重复,cnt为黑洞中数的个数
int next(int n) // 整数n各位数字组成的最大数与最小数的差
{
int a[5],i,j;
for (i=0;i<5;i++)
{
a[i]=n%10;
n/=10;
}
for (i=0;i<4;i++)
for (j=0;j<4-i;j++)
if (a[j]>a[j+1])
{
int t;
t=a[j]; a[j]=a[j+1]; a[j+1]=t;
}
int max=0,min=0;
for (i=0;i<5;i++)
{
min=min*10+a[i];
max=max*10+a[4-i];
}
return max-min;
}
void heidong(int n)
{
int a[20],flag=0;
a[0]=n;
int i,j,k;
for (i=1; ;i++)
{
a[i]=next(a[i-1]);
for (j=0;j<i;j++)
{
if(a[i]==a[j]) // a[j]~a[i-1]之间的数构成循环圈
{
for (k=0;k<cnt;k++) // 看当前循环圈中的数是否保存过,本质是查重
{
if(a[i]==b[k]) { flag=1; break;}
}
if (flag!=1) // 输出循环圈中的各数,同时保存到全局数组b中
{
printf("[%d",a[j]);
b[cnt++]=a[j];
for (k=j+1;k<i;k++)
{
printf(",%d",a[k]);
b[cnt++]=a[k];
}
printf("]\n");
flag=1;
}
}
}
if (flag==1) break;
}
}
int main()
{
int i;
for(i=10000;i<99999;i++)
{
if (next(i)==0) continue; // 各位数字全部相同,忽略
heidong(i);
}
return 0;
}
运行程序可知,所有5位数可能的循环圈有3个,如下。
[74943,62964,71973,83952]
[63954,61974,82962,75933]
[53955,59994]
我正在尝试解析一个CSV文件并使用SQL命令自动为其创建一个表。CSV中的第一行给出了列标题。但我需要推断每个列的类型。Ruby中是否有任何函数可以找到每个字段中内容的类型。例如,CSV行:"12012","Test","1233.22","12:21:22","10/10/2009"应该产生像这样的类型['integer','string','float','time','date']谢谢! 最佳答案 require'time'defto_something(str)if(num=Integer(str)rescueFloat(s
目录一.加解密算法数字签名对称加密DES(DataEncryptionStandard)3DES(TripleDES)AES(AdvancedEncryptionStandard)RSA加密法DSA(DigitalSignatureAlgorithm)ECC(EllipticCurvesCryptography)非对称加密签名与加密过程非对称加密的应用对称加密与非对称加密的结合二.数字证书图解一.加解密算法加密简单而言就是通过一种算法将明文信息转换成密文信息,信息的的接收方能够通过密钥对密文信息进行解密获得明文信息的过程。根据加解密的密钥是否相同,算法可以分为对称加密、非对称加密、对称加密和非
在Ruby中,是否有一种简单的方法可以将n维数组中的每个元素乘以一个数字?这样:[1,2,3,4,5].multiplied_by2==[2,4,6,8,10]和[[1,2,3],[1,2,3]].multiplied_by2==[[2,4,6],[2,4,6]]?(很明显,我编写了multiplied_by函数以区别于*,它似乎连接了数组的多个副本,不幸的是这不是我需要的)。谢谢! 最佳答案 它的长格式等价物是:[1,2,3,4,5].collect{|n|n*2}其实并没有那么复杂。你总是可以使你的multiply_by方法:c
我正在使用Ruby解决一些ProjectEuler问题,特别是这里我要讨论的问题25(Fibonacci数列中包含1000位数字的第一项的索引是多少?)。起初,我使用的是Ruby2.2.3,我将问题编码为:number=3a=1b=2whileb.to_s.length但后来我发现2.4.2版本有一个名为digits的方法,这正是我需要的。我转换为代码:whileb.digits.length当我比较这两种方法时,digits慢得多。时间./025/problem025.rb0.13s用户0.02s系统80%cpu0.190总计./025/problem025.rb2.19s用户0.0
我正在构建一个小部件来显示奥运会的奖牌数。我有一个“国家”对象的集合,其中每个对象都有一个“名称”属性,以及奖牌计数的“金”、“银”、“铜”。列表应该排序:1.首先是奖牌总数2.如果奖牌相同,按类型分割(金>银>铜,即2金>1金+1银)3.如果奖牌和类型相同,则按字母顺序子排序我正在用ruby做这件事,但我想语言并不重要。我确实找到了一个解决方案,但如果感觉必须有更优雅的方法来实现它。这是我做的:使用加权奖牌总数创建一个虚拟属性。因此,如果他们有2个金牌和1个银牌,加权总数将为“3.020100”。1金1银1铜为“3.010101”由于我们希望将奖牌数排序为最高的,因此列表按降序排
我想为名字验证编写一个正则表达式。正则表达式应包括所有字母(拉丁/法语/德语字符等)。但是我想从中排除数字并允许-。所以基本上它是\w(减)数(加)-。请帮忙。 最佳答案 ^[\p{L}-]+$\p{L}匹配anykindofletterfromanylanguage. 关于ruby-on-rails-rails中的正则表达式匹配[\w]和"-"但不匹配数字,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.c
在我的应用程序中,我有一个文本字段,用户可以在其中输入类似这样的内容"1,2,3,4"存储到数据库中。现在,当我想使用内部数字时,我有两个选择:"1,2,3,4".split(',')或string.scan(/\d+/)do|x|a两种方式我都得到一个像这样的数组["1","2","3","4"]然后我可以通过在每个数字上调用to_i来使用这些数字。有没有更好的方法可以转换"1,2,3"to[1,2,3]andnot["1","2","3"] 最佳答案 str.split(",").map{|i|i.to_i}但是这个想法对你来说
我有一个随机大小的散列,它可能有类似"100"的值,我想将其转换为整数。我知道我可以使用value.to_iifvalue.to_i.to_s==value来做到这一点,但我不确定我将如何在我的散列中递归地做到这一点,考虑到一个值可以是一个字符串,或一个数组(哈希或字符串),或另一个哈希。 最佳答案 这是一个非常简单的递归实现(尽管必须同时处理数组和散列会增加一些技巧)。deffixnumifyobjifobj.respond_to?:to_i#IfwecancastittoaFixnum,doit.obj.to_ielsifobj
什么是测试格式验证的最佳方法让我们说一个用户名,使用字母数字的正则表达式,但不是纯数字?我一直在我的模型中使用以下验证validates:username,:format=>{:with=>/^[a-z0-9]+[-a-z0-9]*[a-z0-9]+$/i}数字用户名(例如“342”)通过了验证,这是我不想要的。 最佳答案 您想“向前看”一封信:/\A(?=.*[a-z])[a-z\d]+\Z/i 关于ruby-on-rails-Rails格式验证——字母数字,但不是纯数字,我们在Sta
如果至少有两个相邻的数字相同,格式为,我需要打包.这是我的输入:[2,2,2,3,4,3,3,2,4,4,5]以及预期的输出:"2:3,3,4,3:2,2,4:2,5"到目前为止我试过:a=[1,1,1,2,2,3,2,3,4,4,5]a.each_cons(2).any?do|s,t|ifs==t如果相等,也许可以尝试计数器,但那是行不通的。 最佳答案 您可以使用Enumerable#chunk_while(如果你使用的是Ruby>=2.3):a.chunk_while{|a,b|a==b}.flat_map{|chunk|chu