Java計(jì)算黑洞數(shù)的方法示例
本文實(shí)例講述了Java計(jì)算黑洞數(shù)的方法。分享給大家供大家參考,具體如下:
任意一個(gè)5位數(shù),比如:34256,把它的各位數(shù)字打亂,重新排列,可以得到一個(gè)最大的數(shù):65432,一個(gè)最小的數(shù)23456。求這兩個(gè)數(shù)字的差,得:41976,把這個(gè)數(shù)字再次重復(fù)上述過程(如果不足5位,則前邊補(bǔ)0)。如此往復(fù),數(shù)字會(huì)落入某個(gè)循環(huán)圈(稱為數(shù)字黑洞)。
比如,剛才的數(shù)字會(huì)落入:[82962,75933, 63954, 61974]這個(gè)循環(huán)圈。
請(qǐng)編寫程序,找到5位數(shù)所有可能的循環(huán)圈,并輸出,每個(gè)循環(huán)圈占1行。其中5位數(shù)全都相同則循環(huán)圈為[0],這個(gè)可以不考慮。循環(huán)圈的輸出格式仿照:
[82962,75933, 63954, 61974]
其中數(shù)字的先后順序可以不考慮。
Test.java:
public class Test {
static int r=0;
static int b[]=new int[16];
static int c[]=new int[5];
static int sort(int n,boolean boo) //排序函數(shù)
{
int i,j,sum=0,temp;
int a[]=new int[5];
for(i=0;i<5;i++)
{
a[i]=n%10;
n/=10;
}
for(j=0;j<4;j++)
for(i=0;i<4-j;i++)
{
if(a[i]<a[i+1]&&boo)
{
temp=a[i];
a[i]=a[i+1];
a[i+1]=temp;
}
if(a[i]>a[i+1]&&!boo)
{
temp=a[i];
a[i]=a[i+1];
a[i+1]=temp;
}
}
for(i=0;i<5;i++)
sum+=a[i]*(int)Math.pow(10,4-i);
return sum;
}
static boolean Boo(int d[])//判斷函數(shù)
{
int n,t,q,i,j;
boolean flag=true;
for(i=0;i<16;i++)
for(j=i+1;j<16;j++)
if(b[i]==b[j])//判斷是否有循環(huán)圈存在,只需要判斷是否有相同的一個(gè)數(shù)出現(xiàn)2次就夠了
{
d[0]=i;
d[1]=j;
n=j-i;
for(q=0;q<=r;q++)
for(t=i;t<=j;t++)
if(c[q]==b[t]) flag=false;//用一維數(shù)組存放循環(huán)圈的一位數(shù)(任意一位都可以,這里選取第一位)
if(flag) c[r++]=b[i];//如果新生成的循環(huán)圈中的任何一位與原一維數(shù)組存放的值的不同 則再取循環(huán)圈的一位保存
return flag;
}
return flag;
}
public static void main(String[] args)
{
int n,m,w,t,p;
int r=1;
boolean flag=false;
int d[]=new int[2];
System.out.println("腳本之家測(cè)試結(jié)果:");
for(m=10000;m<100000;m++)
{
n=m;
for(p=0;p<16;p++)
{
w=sort(n,true)-sort(n,false);
b[p]=w;
n=w;
}
if(Boo(d))//輸出不同的循環(huán)圈
{
System.out.printf("[");
for(t=d[0];t<d[1]-1;t++)
System.out.printf("%d,",b[t]);
System.out.printf("%d",b[t]);
System.out.printf("]\n");
}
}
}
}
運(yùn)行結(jié)果:

更多關(guān)于java算法相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java數(shù)學(xué)運(yùn)算技巧總結(jié)》、《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點(diǎn)技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》
希望本文所述對(duì)大家java程序設(shè)計(jì)有所幫助。
- JavaScript黑洞數(shù)字之運(yùn)算路線查找算法(遞歸算法)實(shí)例
- java階乘計(jì)算獲得結(jié)果末尾0的個(gè)數(shù)代碼實(shí)現(xiàn)
- java計(jì)算任意位水仙花數(shù)示例(回文數(shù))
- java計(jì)算自冪數(shù)和水仙花數(shù)
- java中實(shí)現(xiàn)遞歸計(jì)算二進(jìn)制表示中1的個(gè)數(shù)
- Java計(jì)算一個(gè)數(shù)加上100是完全平方數(shù),加上168還是完全平方數(shù)
- java計(jì)算自然數(shù)中的水仙花數(shù)的方法分享
- Java模擬計(jì)算機(jī)的整數(shù)乘積計(jì)算功能示例
- java中的數(shù)學(xué)計(jì)算函數(shù)的總結(jié)
- java精度計(jì)算代碼 java指定精確小數(shù)位
相關(guān)文章
Spring框架中ImportBeanDefinitionRegistrar的應(yīng)用詳解
這篇文章主要介紹了Spring框架中ImportBeanDefinitionRegistrar的應(yīng)用詳解,如果實(shí)現(xiàn)了ImportSelector接口,在配置類中被@Import加入到Spring容器中以后,Spring容器就會(huì)把ImportSelector接口方法返回的字符串?dāng)?shù)組中的類new出來對(duì)象然后放到工廠中去,需要的朋友可以參考下2024-01-01
Eclipse中查看android工程代碼出現(xiàn)"android.jar has no source attachment
這篇文章主要介紹了Eclipse中查看android工程代碼出現(xiàn)"android.jar has no source attachment"的解決方案,需要的朋友可以參考下2016-05-05
SpringMVC中@RequestMapping注解的實(shí)現(xiàn)
RequestMapping是一個(gè)用來處理請(qǐng)求地址映射的注解,本文主要介紹了SpringMVC中@RequestMapping注解的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01
淺談synchronized方法對(duì)非synchronized方法的影響
下面小編就為大家?guī)硪黄獪\談synchronized方法對(duì)非synchronized方法的影響。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-10-10
springMVC獲取請(qǐng)求參數(shù)的幾種方式匯總
在日常使用SpringMVC進(jìn)行開發(fā)的時(shí)候,有可能遇到前端各種類型的請(qǐng)求參數(shù),這里做一次相對(duì)全面的總結(jié),下面這篇文章主要給大家介紹了關(guān)于springMVC獲取請(qǐng)求參數(shù)的幾種方式,需要的朋友可以參考下2022-04-04
基于@RequestBody注解只能注入對(duì)象和map的解決
這篇文章主要介紹了@RequestBody注解只能注入對(duì)象和map的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10
hadoop中實(shí)現(xiàn)java網(wǎng)絡(luò)爬蟲(示例講解)
下面小編就為大家?guī)硪黄猦adoop中實(shí)現(xiàn)java網(wǎng)絡(luò)爬蟲(示例講解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-09-09
SpringBoot上傳文件到本服務(wù)器 目錄與jar包同級(jí)問題
這篇文章主要介紹了SpringBoot上傳文件到本服務(wù)器 目錄與jar包同級(jí)問題,需要的朋友可以參考下2018-11-11
關(guān)于Java中數(shù)組切片的幾種方法(獲取數(shù)組元素)
這篇文章主要介紹了關(guān)于Java中數(shù)組切片的幾種方法(獲取數(shù)組元素),切片是數(shù)組的一個(gè)引用,因此切片是引用類型,在進(jìn)行傳遞時(shí),遵守引用傳遞的機(jī)制,需要的朋友可以參考下2023-05-05
mybatis多個(gè)接口參數(shù)的注解使用方式(@Param)
這篇文章主要介紹了mybatis多個(gè)接口參數(shù)的注解使用方式(@Param),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-10-10

