任意一个5位数,比如:34256,把它的各位数字打乱,重新排列,可以得到一个最大的数:65432,一个最小的数23456。求这两个数字的差,得:41976,把这个数字再次重复上述过程(如果不足5位,则前边补0)。如此往复,数字会落入某个循环圈(称为数字黑洞)。
比如,刚才的数字会落入:[82962, 75933, 63954, 61974] 这个循环圈。
请编写程序,找到5位数所有可能的循环圈,并输出,每个循环圈占1行。其中5位数全都相同则循环圈为 [0],这个可以不考虑。循环圈的输出格式仿照:
[82962, 75933, 63954, 61974]
其中数字的先后顺序可以不考虑。
(代码其实并不算长,只是注释写多了。如果有更好的方法,望赐教。)
/**
* @category 数字黑洞
* @author liucanwen
* @time 2012-1-17 20:30
*/
public class NumberBlackHole
{
@SuppressWarnings("unchecked")
ArrayList list = null;
@SuppressWarnings("unchecked")
public static void main(String[] args) throws Exception
{
NumberBlackHole nbh = new NumberBlackHole();
//循环:从10000~99999的所有五位数,求出所有5位数的数字黑洞
for(int i = 10000; i <= 99999; i++)
{
//当数字可以整除11111直接输出"[0]"
if(i % 11111 == 0)
{
//System.out.println("[0]");
continue;
}
//调用方法getCycle()来得到数字序列list
ArrayList list2 = nbh.getCycle(i, 0);
//标志索引:数字黑洞的开始索引。
int deleteIndex = 0;
//遍历得到的list2(数字序列)
for(int j = 0; j < list2.size(); j++)
{
//得到数字黑洞的开始索引
if(list2.get(j).equals(list2.get(j + 4)))
{
deleteIndex = j;
break;
}
}
//删除数字黑洞开始索引之前的数字
for(int k = 0; k < deleteIndex; k++)
{
list2.remove(0);
}
//删除数字黑洞之后的数字,只保留数字黑洞一次循环体
for(int m = 0; m < 10 - deleteIndex - 4; m++)
{
list2.remove(list2.size() - 1);
}
//打印数字黑洞的一次循环体
System.out.println(list2);
}
}
/**
* @param number 传过来的5位数
* @param index 是该方法在递归的时候做标识退出
* @return ArrayList 装有数字黑洞的数字序列
*/
@SuppressWarnings("unchecked")
public ArrayList getCycle(int number, int index)
{
//首次进入该方法,创建一个ArrayList,用于装数字序列
if(0 == index) list = new ArrayList();
//当递归十次,返回长度为10的数字序列list
if(10 == index) return list;
//把传过来的数字转换成String,再把String转换成char[]数组
String str = String.valueOf(number);
char[] chars = str.toCharArray();
//再对数组进行升序排序,从而得到最大值和最小值
Arrays.sort(chars);
//初始化传过来的五位数字
int first = 0;
int second = 0;
int three = 0;
int four = 0;
int five = 0;
//当最大值-最小值得到的结果为五位数
if(5 == chars.length)
{
first = Integer.parseInt(String.valueOf(chars[0]));
second = Integer.parseInt(String.valueOf(chars[1]));
three = Integer.parseInt(String.valueOf(chars[2]));
four = Integer.parseInt(String.valueOf(chars[3]));
five = Integer.parseInt(String.valueOf(chars[4]));
}
//当最大值-最小值得到的结果为四位数
else if(4 == chars.length)
{
second = Integer.parseInt(String.valueOf(chars[0]));
three = Integer.parseInt(String.valueOf(chars[1]));
four = Integer.parseInt(String.valueOf(chars[2]));
five = Integer.parseInt(String.valueOf(chars[3]));
}
//当最大值-最小值得到的结果为三位数
else if(3 == chars.length)
{
three = Integer.parseInt(String.valueOf(chars[0]));
four = Integer.parseInt(String.valueOf(chars[1]));
five = Integer.parseInt(String.valueOf(chars[2]));
}
//当最大值-最小值得到的结果为二位数
else if(2 == chars.length)
{
four = Integer.parseInt(String.valueOf(chars[0]));
five = Integer.parseInt(String.valueOf(chars[1]));
}
//当最大值-最小值得到的结果为一位数
else if(1 == chars.length)
{
five = Integer.parseInt(String.valueOf(chars[0]));
}
else
{
return null;
}
//把传过来的五位数排成最大值和最小值
int minValue = first*10000 + second*1000 + three*100 + four*10 + five;
int maxValue = first + second*10 + three*100 + four*1000 + five*10000;
//得到最大值-最小值的差count
int count = maxValue - minValue;
//把上面得到的差count放到list当中
list.add((Integer)count);
//进行递归,递归结束条件由index来控制
getCycle(count, index + 1);
return list;
}
}
分享到:
相关推荐
5--[数字黑洞1和4].zip源码scratch2.0 3.0编程项目源文件源码案例素材源代码5--[数字黑洞1和4].zip源码scratch2.0 3.0编程项目源文件源码案例素材源代码5--[数字黑洞1和4].zip源码scratch2.0 3.0编程项目源文件源码...
算法提高 数字黑洞 时间限制:1.0s 内存限制:256.0MB 问题描述 任意一个四位数,只要它们各个位上的数字是不全相同的,就有这样的规律:
5--[123数字黑洞].zip源码scratch2.0 3.0编程项目源文件源码案例素材源代码5--[123数字黑洞].zip源码scratch2.0 3.0编程项目源文件源码案例素材源代码5--[123数字黑洞].zip源码scratch2.0 3.0编程项目源文件源码案例...
黑洞探秘黑洞探秘黑洞探秘黑洞探秘黑洞探秘黑洞探秘黑洞探秘
NSF-PROD-ADS-V4-DC-黑洞旁路配置手册
黑洞数算法的实现。黑洞数是各位数字均不相同的整型数字,持续 进行 最大排列数-最小排列数 操作,当结果循环出现时,即为黑洞数。
我们研究了极端Kerr-Taub-NUT黑洞时空中近地平线区域的电磁线发射,然后研究了NUT电荷对电磁线发射的影响。 由于存在NUT电荷,赤道平面不再是KTN时空的对称平面,这导致南半球观测者电磁线发射对NUT电荷的依赖性不同...
c++经典程序 int main() { srand((unsigned)time(NULL)); //时钟振荡产生随机数 int number = rand() % 10000; cout 产生的随机数为: "; int value = blackHoleNumber(number)... cout 黑洞数为: " ; return 0; }
我们发现非极端的Kerr-Newman-NUT-AdS黑洞在全息上与隐藏的二维共形场理论相对应。 我们显式地构造了对黑洞双重的两个不同的共形场理论(称为J和Q图片),它们对应于角动量J和黑洞的电荷Q。 此外,我们表明这两个...
在本文中,我们研究了扩展相空间中Kerr-AdS黑洞的Joule-Thomson展开。 推导了Kerr-AdS黑洞的Joule-Thomson展开公式。 我们研究了T – P平面上的等焓和数值倒转曲线,并证明了Kerr–AdS黑洞的冷却-加热区域。 我们还...
6174数字黑洞-少儿编程scratch项目源代码文件案例素材.zip
123数字黑洞-少儿编程scratch项目源代码文件案例素材.zip
主要介绍了Java编程中如何实现数字黑洞算法游戏,其中涉及到了数组、scanner、if语句等Java编程的基础知识,需要的朋友可以参考下
在这封信中,我们探索了另一个新颖的Ehrenfest方案,该方案也可用于RN-AdS黑洞的PV临界研究中。 Ehrenfest方案的新颖形式既不是古典热力学中的一种,也不是文献中为大正则合奏提出的类推。 在详细推导了新的埃伦...
我们提出了新的解析旋转四维反de Sitter空间(AdS4)黑洞,这些黑洞是经测量的N = 2超重与对称标量流形耦合到Abelian向量多重性的解决方案。 这些配置保留了两个实际的增压,并且对BPS Kerr-Newman-AdS4黑洞具有平滑...
Scratch少儿编程项目源代码文件案例蓝桥训练-数字黑洞.zip
7-1 黑洞数 (20分) 黑洞数也称为陷阱数,又称“Kaprekar问题”,是一类具有奇特转换特性的数。 任何一个各位数字不全相同的三位数,经有限次“重排求差”操作,总会得到495。最后所得的495即为三位黑洞数。所谓...
我们在爱因斯坦-魏尔引力的大规模引力理论中研究Schwarzschild-AdS黑洞的经典稳定性。 事实证明,线性化的爱因斯坦张量摄动表现出不稳定的模式,其特征在于五维AdS黑线的Gregory-Laflamme不稳定性,与爱因斯坦引力中...
我们在接近极值的D1-D5和D1-D5-P黑洞中测试了该建议,并表明它们的热力学也可以用类似的方式来解释,即通过相互作用的基本D1-脑和D5-脑的集体运动来解释。 (和波浪)。 这可能意味着在统一的图片中解释了这些相交...