问题叙述如下:
“2520是最小的数能够整除1到10,求能被1到20所整除的最小的数?”
代码如下:
/**
* 数字i从m到n,遍历,如果i不能被result整除,我们就将i除以i与result的最大公约数,并与当前result想乘
*
*/
private static int getNumber(int m, int n) {
int result = n;
for (int i = n - 1; i >= m; i--) {
if (result % i != 0) {
result *= i/gcd(result,i);
}
}
return result;
}
/**
* 最大公约数:欧几里德算法 定理:gcd(a,b) = gcd(b,a mod b)
*
* @param a
* @param b
* @return
*/
private static int gcd(int a, int b) {
if (b != 0)
return gcd(b, a % b);
else
return a;
}
调用getNumber(1,20)即可得到答案232792560。
由于在此用到最大公约数,所以在下面给出了一些实现。
/**
* 最大公约数:欧几里德算法
* @param a
* @param b
* @return
*/
private static int gcd1(int a, int b) {
if (a > b) {
gcd1(b, a);
}
int temp = 0;
for (; b != 0;) {
temp = a % b;
a = b;
b = temp;
}
return a;
}
/**
* 最大公约数:Stein算法 gcd(ka,kb) = k gcd(a,b),也就是最大公约数运算和倍乘运算可以交换,
* 特殊的,当k=2时,说明两个偶数的最大公约数必然能被2整除
*
* @param a
* @param b
* @return
*/
private static int gcdByStein(int a, int b) {
if (a > b) {
gcdByStein(b, a);
}
if (b == 0) {
return a;
}
if (a % 2 == 0 && b % 2 == 0) {
return 2 * gcdByStein(a / 2, b / 2);//a,b都是偶数
}
if (a % 2 == 0) {
return gcdByStein(a / 2, b);//仅a为偶数
}
if (b % 2 == 0) {
return gcdByStein(a, b / 2);//仅b为偶数
}
return gcdByStein((a + b) / 2, (a - b) / 2);//a,b都是奇数
}
如果有其他的方法,也请贴出大家一起讨论。^_^
请不吝赐教。
@anthor ClumsyBirdZ
分享到:
相关推荐
delphi制作的简易程序,用来计算1000-4000能被7和17整除的数,用memo显示出来。
2520是最小的能被1-10中每个数字整除的正整数。 最小的能被1-20中每个数整除的正整数是多少? 保证运行出结果
在1-100之间整除3又能整除5的数,则显示"FLIPFLOP", 如果能整除3,则显示"FLIP", 如果能整除3,则显示"FL0P" 如中不能整除3又不能整除5时,则输出这个数!
用java编写的求1到100以内的前5个可以被3整除的数字
1至100能被7整除的数,C#小练习
Java程序,1到100可以被2,3,5整除的数
C语言编写输出2到100不能同时被2或5整除的数,练习continue的使用区分break。
内容概要:输入一个数n,输出1——n之间不能被5整除的数,一行5个数(JAVA) 适用人群:新手初学者小白 学到什么:输入输出语句、for循环控制语句、if条件控制语句、\t制表符、自增/自减的运用 、赋值语句和判断语句...
1-999中能被3整除,且至少有一位数字是5的所有整数,经典例题
求100—200之间不能被3整除的数 C++语言程序设计(第3版)郑莉等编著
VB随堂作业详细资料 100---600能被整除的数的详细设计方法 好用
1_求1到1000中,能被7整除的数的个数.c
js计算出1000内可以被3,5,7整除的数并输出这些数和数量到网页中
用sql语句实现求100以内能被5整除的和,简单易懂,思路清晰,特别适合初学者的学习
自己写的,求被13整除的数,这是个自己写的小例子。
输出两个数之间能被5整除的数的和 <html><body> [removed] var n=0; var a=parseInt(prompt("请输入第一个数:")); var b=parseInt(prompt("请输入第二个数:")); if(a>b) {[removed](b+"到"+a+"之间能被5...
300-500被9整除最大和最小的数.
求100以内能被3整除的数,简单而又实用。
C语言程序设计-判断一个整数w的各位数字平方之和能否被5整除,可以被5整除则返回1,否则返回0;
洗牌程序 指针与二维数组元素的关系 在屏幕上画变化的圆 求同时能被3和4整除的数