倍逆序式

import java.util.Scanner;

public class Testa {

public static void main(String[] args) {
	System.out.println("请输入n:(代表求多少个连续的合数)");
	Scanner reader=new Scanner(System.in);
	int n=reader.nextInt();
	int min=(int) Math.pow(10,n-1);
	int max=(int) (Math.pow(10,n)-1);
	int total=0;
   for(int i=min;i<max;i++){
	   boolean x=f(i);
	   if(x){
		   boolean ok=k(i);
		   if(ok){
			   System.out.println("符合条件:"+i);
		   }
		   
	   }
   }
 }	
	

//去重

public static boolean f(int n){

	String result=String.valueOf(n);
	
	int length=result.length();
	
	for(int i=0;i<length-1;i++){
		for(int j=i+1;j<length;j++){
			char a=result.charAt(i);
			char b=result.charAt(j);
			if(a==b){
				return false;
			}
		}
	}
	
	return true;
	
}


 //将数逆序,n代表传入的数

public static boolean k(int n){
	
	int m=n;
	String result=String.valueOf(m);
	int leng=result.length()-1;
	int length=leng;
	int temp;
	int sum;
	sum=0;
	
	temp=m%10;
	sum =(int) (sum+Math.pow(10,leng)*temp);
	
	m=m/10;
	
	while(m>=10){
		temp=m%10;
		leng--;
		sum=(int) (sum+Math.pow(10,leng)*temp);
		m=m/10;
	}
	leng--;
	sum=(int) (sum+Math.pow(10,leng)*m);
     String result1=String.valueOf(sum);
     int length1=result1.length();
     if(n<sum){
    	 int k=sum/n;
    	 if(k*n==sum){
    		 return true;
    	 }
     }
	return false;
	
}

}

转载于:https://my.oschina.net/u/2511906/blog/847272

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值