如何在Java中检查一个数字是否为Harshad数?
Harshad数可以被其数字之和整除。简单来说,如果一个数的所有数字之和是该数的因子,那么它就是一个Harshad数。
在本文中,我们将看到如何使用Java编程语言来检查Harshad数。
向您展示一些实例
实例1
输入数字为18
让我们使用Harshad数的逻辑来检查它−
数字的各位数字之和 = 1 + 8 = 9。
所以,18可以被9整除。
因此,18是一个Harshad数。
Instance-2
的翻译为:实例-2
输入的数字是3
让我们使用Harshad数的逻辑来检查它−
数字的各位数之和 = 3。
所以,3可以被3整除。
因此,3 是哈沙德数。
Instance-3
的中文翻译为:实例-3
输入数字为15
让我们使用Harshad数的逻辑来检查它−
数字的各位数字之和 = 1 + 5 = 6。
所以,15 不能被 6 整除。
因此,14 不是哈沙德数。
一些其他的哈尔沙德数的例子包括 1、2、4、5、6、7、8、9、10、12、18、20 等。
语法
使用内置的 toString()方法将整数值转换为字符串值。
以下是将整数值转换为字符串值,然后找到其长度并将长度赋值给整数变量以获取数字中总位数的语法 -
String str = Integer.toString(input_number);
要获取整数的长度,我们将使用Java String类内置的length()方法 方法返回 String 对象的长度。
int length = st.length();
要获取字符串中特定位置/索引处的字符,我们使用 charAt() 方法。其中 charAt(i)-‘0’ 返回实际的整数值。
int num = st.charAt(i)-‘0’;
其中“st”指的是字符串,“i”是迭代该字符串的迭代器变量。
算法
算法1
第 1 步 - 通过初始化或用户输入获取整数。
第 2 步 - 通过迭代数字的每个数字,找到数字的每个数字的总和。
步骤3 - 然后检查原始数字是否可被数字的所有位数之和整除。如果可被整除,则给定的数字是一个Harshad数,否则不是一个Harshad数
算法2
第 1 步 - 通过初始化或用户输入获取整数。
第 2 步 - 使用内置的 toString() 方法将该整数转换为字符串。
步骤 3 - 通过使用内置的 length() 方法找到字符串的长度。
步骤 4 - 然后通过使用 for 循环,迭代直到字符串的长度,并使用 charAt(i)-' 从字符串中获取一一整数值0' 并记录所有数字的总和。
步骤 5 - 然后检查原始数字是否可以被该数字所有数字的总和整除。如果可整除,则给定的数字是哈沙德数,否则不是哈沙德数。
多种方法
我们提供了不同方法的解决方案
不使用字符串
通过使用字符串
让我们一一看看该程序及其输出。
方法 1:不使用字符串
在这种方法中,程序中将初始化一个整数值,然后通过使用Algorithm-1我们可以检查一个数是否是Harshad数。
示例
public class Main{ //main method public static void main(String args[]){ //Declared an integer variable and initialized a number as value int originalNumber = 21; //printing the given number to be checked System.out.println("Given number: "+originalNumber); //keep a copy of original number int copyOfOriginalNumber = originalNumber; //initialize sum as 0 int sum = 0; //Find sum of all digits of the number //continue the loop till the number is greater than 0 while(originalNumber > 0){ //get the rightmost digit of the number by using % operator int rem = originalNumber%10; //add the digit(rem) to sum sum = sum + rem; //remove the rightmost digit from number and get the updated number originalNumber = originalNumber/10; } //printing the result if(copyOfOriginalNumber % sum == 0) System.out.println(copyOfOriginalNumber+" is a Harshadnumber"); else System.out.println(copyOfOriginalNumber+" is not a Harshadnumber"); } }
输出
Given number: 21 21 is a Harshad number
方法 2:使用字符串
在这种方法中,将在程序中初始化一个整数值,然后使用 Algorithm-2 我们将检查该数字是否为 Harshad 数字。
示例
public class Main{ //main method public static void main(String args[]){ //Declared an integer variable and initialized a number as value int originalNumber = 40; //printing the given number to be checked System.out.println("Given number: "+originalNumber); //keep a copy of original number int copyOfOriginalNumber = originalNumber; //initialize sum as 0 int sum = 0; //convert the integer to string by using toString() method String str = Integer.toString(originalNumber); //find length of String by using length() method //which is nothing but total number of digits in the given number int length=str.length(); //iterate the String and get the digits by using charAt(i)-'0' //find the sum of digits for(int i = 0; i < length; i++){ sum += str.charAt(i)-'0'; } //printing the result if(copyOfOriginalNumber % sum == 0) System.out.println(copyOfOriginalNumber+" is a Harshad number"); else System.out.println(copyOfOriginalNumber+" is not a Harshad number"); } }
输出
Given number: 40 40 is a Harshad number
在本文中,我们探讨了如何使用不同的方法在 Java 中检查一个数字是否为 Harshad 数字。
以上是如何在Java中检查一个数字是否为Harshad数?的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

Java 8引入了Stream API,提供了一种强大且表达力丰富的处理数据集合的方式。然而,使用Stream时,一个常见问题是:如何从forEach操作中中断或返回? 传统循环允许提前中断或返回,但Stream的forEach方法并不直接支持这种方式。本文将解释原因,并探讨在Stream处理系统中实现提前终止的替代方法。 延伸阅读: Java Stream API改进 理解Stream forEach forEach方法是一个终端操作,它对Stream中的每个元素执行一个操作。它的设计意图是处

全球虚拟币交易平台2025年排行榜前四名依次为: 币安:行业龙头,提供多样化交易选择和创新产品。 OKX:庞大用户群,提供全面加密货币服务。 Gate.io:用户友好,提供广泛加密货币选择。 Bitget:专注于衍生品交易,提供高杠杆期货合约。

胶囊是一种三维几何图形,由一个圆柱体和两端各一个半球体组成。胶囊的体积可以通过将圆柱体的体积和两端半球体的体积相加来计算。本教程将讨论如何使用不同的方法在Java中计算给定胶囊的体积。 胶囊体积公式 胶囊体积的公式如下: 胶囊体积 = 圆柱体体积 两个半球体体积 其中, r: 半球体的半径。 h: 圆柱体的高度(不包括半球体)。 例子 1 输入 半径 = 5 单位 高度 = 10 单位 输出 体积 = 1570.8 立方单位 解释 使用公式计算体积: 体积 = π × r2 × h (4

Java是热门编程语言,适合初学者和经验丰富的开发者学习。本教程从基础概念出发,逐步深入讲解高级主题。安装Java开发工具包后,可通过创建简单的“Hello,World!”程序实践编程。理解代码后,使用命令提示符编译并运行程序,控制台上将输出“Hello,World!”。学习Java开启了编程之旅,随着掌握程度加深,可创建更复杂的应用程序。

Spring Boot简化了可靠,可扩展和生产就绪的Java应用的创建,从而彻底改变了Java开发。 它的“惯例惯例”方法(春季生态系统固有的惯例),最小化手动设置

JavaMadeSimple:ABeginner'sGuidetoProgrammingPower简介Java是一种强大的编程语言,广泛应用于从移动应用程序到企业级系统的各种领域。对于初学者来说,Java的语法简洁易懂,是学习编程的理想选择。基本语法Java使用基于类的面向对象编程范式。类是将相关数据和行为组织在一起的模板。以下是一个简单的Java类示例:publicclassPerson{privateStringname;privateintage;

堆栈是遵循LIFO(最后,首先)原理的数据结构。换句话说,我们添加到堆栈中的最后一个元素是第一个要删除的元素。当我们将(或推)元素添加到堆栈中时,它们就会放在顶部;即最重要的

本教程将指导您如何使用 Java 将堆栈元素按升序排序。堆栈是计算机科学中的基本数据结构,遵循后进先出 (LIFO) 原则。 我们将分解一种简单而有效的方法,该方法使用额外的临时堆栈,提供详细的分步说明,并包含完整的代码示例。本教程非常适合那些希望增强对堆栈操作的理解并提高 Java 编程技能的人。 使用 Java 将堆栈按升序排序 堆栈就像一堆书,你只能取走最上面的那本。即,堆栈以后进先出的 (LIFO) 方式存储项目。最后添加的项目是第一个被移除的项目。以下是使用辅助堆栈对堆栈元素进行排序的
