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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 2022年G3锅炉水处理找解析及G3锅炉水处理考试试卷[通俗易懂]

    题库来源:安全生产模拟考试一点通公众号小程序安全生产模拟考试一点通:G3锅炉水处理找解析是安全生产模拟考试一点通生成的,G3锅炉水处理证模拟考试题库是根据G3锅炉水处理最新版教材汇编出G3锅炉水处理仿真模拟考试。2022年G3锅炉水处理找解析及G3锅炉水处理考试试卷1、【多选题】水垢对锅炉的危害主要有浪费燃料()。(ABD)A、.损坏锅炉受热面B、.降低锅炉出力C、.减少供汽时间D、.缩短锅炉使用寿命E、.提高了环境温度2、【多选题】特种设备作业人员应当遵守()规…

    2022年4月14日
    47
  • 接口测试工具Postman接口测试图文教程

    接口测试工具Postman接口测试图文教程市场上有很多优秀的,完善的接口测试工具,比如SoapUI,Postman等,能够高效的帮助后端开发人员独立进行接口测试。这里使用Postman接口测试工具,此处以请求方式为POST的userLogin登录接口为例。

    2022年5月31日
    57
  • continue的使用方法_后来终于明白

    continue的使用方法_后来终于明白//tsk.cpp:定义控制台应用程序的入口点。//#include"stdafx.h"intmain(){while(1){if(1){conti

    2022年8月6日
    3
  • vue 分页 Pagination

    vue 分页 Pagination<el-pagination@size-change=”handleSizeChange”@current-change=”handleCurrentChange” :current-page.sync=”paging.currentPage”:page-sizes=”paging.pageSizes” :page-size=”paging.pageSize”layout=”total,prev,pager,next,jumper” :total=”paging.total”.

    2022年10月1日
    3
  • Assigning retained object to unsafe property;object will be released after assignment「建议收藏」

    Assigning retained object to unsafe property;object will be released after assignment

    2022年2月2日
    37
  • 期货软件开发与平台搭建注意事项是什么_手机期货程序化交易软件

    期货软件开发与平台搭建注意事项是什么_手机期货程序化交易软件期货软件开发和期货平台搭建需要注意很多内容,关系到后期运营的是否正常稳定。现在市面上的很多的期货交易系统软件平台,基本都支持支持PC、安卓APP端,微信端、且具备风控系统、杠杆系统、交易系统、在线出入金、后台管理系统、代理系统、股票数据行情等功能。但是行业鱼龙混杂,并不是每一家开发公司都是靠谱的。加wx:“Zhangyoukeji001”发送相关演示版与报价!  作为投资者,要想拥有一个可靠的期货交易系统,需要注意以下几点:前期对期货系统软件的功能规划——针对期货系统软件,要有具体的规划方案,需

    2025年10月21日
    2

发表回复

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

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