纯净、安全、绿色的下载网站

首页|软件分类|下载排行|最新软件|IT学院

当前位置:首页IT学院IT技术

Java C语言 水仙花数 Java和C语言分别实现水仙花数及拓展代码

愿百事可乐   2021-11-19 我要评论
想了解Java和C语言分别实现水仙花数及拓展代码的相关内容吗,愿百事可乐在本文为您仔细讲解Java C语言 水仙花数的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:Java水仙花数,C语言水仙花数,下面大家一起来学习吧。

前言

求出0~999之间的所有“水仙花数”并输出。(“水仙花数”是指一个三位数,其各位数字的立方和确好等于该数本身,如;153=1+5+3?,则153是一个“水仙花数”。)

一、水仙花数

因为水仙花数是三位数,所以我们把范围定为100~999。

1.代码(Java)

public class Num {
    public static void main(String[] args) {
        for(int n = 100;n <= 999;n++){
            int count = 0;
            int tmp = n;
            while(tmp != 0){
                count++;
                tmp = tmp/10;
            }
            tmp = n;
            int sum = 0;
            while(tmp != 0){
                sum += Math.pow(tmp%10,count);
                tmp = tmp/10;
            }
            if(sum == n){
                System.out.println(sum);
            }
        }
    }
}

2.运行结果(Java)


3.代码(C语言)

其中的一种方法,只输出水仙花数,下文会进行拓展。

#include <stdio.h>
int main()
{
	int n = 0;
	int a, b, c = 0;
	printf("水仙花数为:\n");
	for (n = 100; n <= 999; n++)
	{
		a = n / 100;
		b = n / 10 % 10;
		c = n % 100 % 10;
		if (n == a * a * a + b * b * b + c * c * c)
			printf("%d\n", n);
	}
	return 0;
}

4.运行结果(C语言)


二、拓展

已知三位自幂数为水仙花数,一位自幂数为独身数,不存在二位自幂数,以此类推还有四叶玫瑰数,五角星数,六合数,北斗七星数,八仙数,九九重阳数,十全十美数的自幂数。

求出0-100000中的自幂数?

只要将上文代码稍微改下数值就可以实现。

1.代码(Java)

public class Num {
    public static void main(String[] args) {
        for(int n = 0;n <= 100000;n++){
            int count = 0;
            int tmp = n;
            while(tmp != 0){
                count++;
                tmp = tmp/10;
            }
            tmp = n;
            int sum = 0;
            while(tmp != 0){
                sum += Math.pow(tmp%10,count);
                tmp = tmp/10;
            }
            if(sum == n){
                System.out.println(sum);
            }
        }
    }
}

2.运行结果(Java)

3.代码(C语言)

由于上文提到的方法只适用于三位数,显然不能输出0-100000中的所有自幂数,所以我们用适用更广的方法。

#include <stdio.h>
#include <math.h>
int main()
{
	int n = 0;
	
	for (n = 0; n <= 100000; n++)
	{
		int count = 1;
		int tmp = n;
		int sum = 0;
		while (tmp/10)
		{
			tmp = tmp / 10;
			count++;
		}
		tmp = n;
		while (tmp)
		{
			sum = pow(tmp % 10, count) + sum;
			tmp = tmp / 10;
		}
		if (sum == n)
			printf("%d\n", sum);
	}
	return 0;
}

可以看到两种语言的代码都很相似。

4.运行结果(C语言)


相关文章

猜您喜欢

  • Python Opencv文本检测 Python+Opencv文本检测的实现

    想了解Python+Opencv文本检测的实现的相关内容吗,AI浩在本文为您仔细讲解Python Opencv文本检测的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:Python文本检测,Python,Opencv文本检测,下面大家一起来学习吧。..
  • Springboot AOP 数据加密存储 Springboot AOP对指定敏感字段数据加密存储的实现

    想了解Springboot AOP对指定敏感字段数据加密存储的实现的相关内容吗,小目标青年在本文为您仔细讲解Springboot AOP 数据加密存储的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:Springboot数据加密存储,Springboot,AOP,数据加密存储,下面大家一起来学习吧。..

网友评论

Copyright 2020 www.mutouboke.com 【木头软件站】 版权所有 软件发布

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 点此查看联系方式