杭电acm1719

http://acm.hdu.edu.cn/showproblem.php?pid=1719

题目意思:

1. 定义1 和 2 是两个“友好数”
2. 如果a是“友好数”,b也是“友好数”,则(a * b + a + b )也是一个“友好数”

现在任意给定一个整数 a(0<=a<=2^30),让你判断 a 是不是 “友好数”

解题思路:

设任意数 n 为一个“友好数”,则 n = a * b + a + b (其中a和b都是友好数)
  n = a * b + a + b
==》n+1 = (a+1)*(b+1)

因为a 和 b 都是友好数,则 a= a1*a2+a1+a2 ==》a+1= (a1+1)*(a2+1) (其中a1和a2都是友好数),
同理,b+1= (b1+1)*(b2+1) (其中b1和 b2都是友好数)

==》n+1 = (a+1)*(b+1) = (a1+1)*(a2+1) * (b1+1)*(b2+1) = ······ ······ = (1+1)^x * (2+1)^y = 2^x * 3^y (其中x和y为大于等于0的正整数)
即,
n+1 = 2^x * 3^y

所以可知任意给定的友好数n,则有(n+1)能够整除2或者能够整除3。

====================================================================================================================================

由上分析可以写成如下代码:

<span style="font-size:18px;">import java.util.Scanner;

public class Main {

	static Scanner scanner = new Scanner(System.in);
	static int n;
	static int x;

	public static void main(String[] args) {

		while (scanner.hasNext()) {
			n = scanner.nextInt();
			x = n + 1;
			boolean flag = false;
			if (n != 0) {
				while (x % 2 == 0 || x % 3 == 0) {
					
					if (x % 2 == 0) {
						x = x / 2;
					}
					if (x % 3 == 0) {
						x = x / 3;
					}
				}
				
				if (x == 1) {
					flag = true;
				}
			}
			if (flag) {
				System.out.println("YES!");
			} else {
				System.out.println("NO!");
			}

		}

	}

}
</span>


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值