poj1142_poj是什么意思

poj1142_poj是什么意思poj1142题解

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

题目链接:http://poj.org/problem?id=1142

题意:找出smith数。smith数是一个数的各个位之和等于其因子的各个位之和。

解题思路:从2一直向上扫描,遇到能除的就除,求出数字的质因数

import java.util.Scanner;

public class Main{
	public static void main(String[] args){
		Scanner sc = new Scanner(System.in);
		int n = sc.nextInt();
		while(n != 0){
			get(n);
			n=sc.nextInt();
		}
		sc.close();
	}

	private static void get(int n) {
		while(true){
			n++;
			if(!isPrim(n)){
				if(isSmithNumber(n)){
					System.out.println(n);
					break;
				}
			}
		}
	}

	private static boolean isSmithNumber(int n) {
		int k=n;
		int sum = 0;
		int total = 0;
		while(k/10 != 0){
			sum += k % 10;
			k = k / 10;
		}
		sum += k;
		for(int i =2; i <= (int)Math.sqrt(n);){
			if(n % i == 0){
				n=n / i;
				total += getSum(i);
			}
			else
				i++;
		}
		total += getSum(n);
		if(sum == total)
			return true;
		return false;
	}

	private static int getSum(int i) {
		int sum = 0;
		int k=i;
		while(k / 10 != 0){
			sum += k % 10;
			k = k / 10;
		}
		sum += k;
		return sum;
	}

	private static boolean isPrim(int n) {
		int m = (int) Math.sqrt(n);
		if(n == 2)
			return true;
		if(n%2 == 0)
			return false;
		for(int i = 3; i <= m; i = i + 2){
			if(n % i == 0)
				return false;
		}
		return true;
	}
	
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/187160.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • MySQL查看用户权限及权限管理

    MySQL查看用户权限及权限管理一、MySQL权限级别介绍全局——可以管理整个MySQL库——可以管理指定的数据库表——可以管理指定数据库的指定表字段——可以管理指定数据库的指定表的指定字段权限存储在mysql库的user,db,tables_priv,columns_priv,procs_priv这几个系统表中,待MySQL实例启动后就加载到内存中二、查看用户权限1、查看所有用户(用户名、给谁授权)…

    2022年6月18日
    68
  • 小微型库(3.绑定on和解绑off)

    小微型库(3.绑定on和解绑off)小微型库(3.绑定on和解绑off)

    2022年4月20日
    45
  • pinetwork节点教程_搭建ss教程

    pinetwork节点教程_搭建ss教程文章目录1、简介2、Pi节点安装2.1、操作系统2.2、路由器设置2.3、Docker安装2.4、PiNode安装1、简介    2020年3月31日(太平洋时间)Node软件的测试版上线此,版本号0.015。写下这篇文章时,版本号已更新至0.3.8。Pi节点的安装设置过程稍复杂,在此做个总结。2、Pi节点安装2.1、操作系统2.2、路由器设置2.3、Docker安装2.4、PiNode安装…

    2022年10月8日
    0
  • windows 设置定时锁屏

    windows 设置定时锁屏设置间隔指定时间电脑自动锁屏CreateTime–2017年7月3日10:16:14Author:Marydon参考地址:电脑爱好者杂志举例:实现每间隔45分钟,电脑自动锁屏实现思路:  第一步:编写锁屏命令;  第二步:制定计划。实践:  1.编写锁屏命令    新建一个txt文件,重命名为:lockScreen(名字随意)–>打开该文件添…

    2022年7月21日
    53
  • System.getProperty()

    System.getProperty()System类来自于这个包:java.lang.SystemSystem.getProperty("XXX")方法用来读取JVM中的系统属性,那么java虚拟机中的系统属性使用

    2022年7月3日
    19

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号