当前位置: 首页 > article >正文

【蓝桥杯】46195.水仙花数

水仙花数

问题描述

打印所有100至999之间的水仙花数。所谓水仙花数是指满足其各位数字立方和为该数字本身的整数,例如 153=13+53+33

样例输入

样例输出

153
370
371
407

解题思路

  1. 遍历100到999之间的所有整数。
  2. 对每个整数,计算其各位数字的立方和。
  3. 如果立方和等于该数字,则打印该数字。

代码展示

Python 实现

# 遍历100到999之间的所有数字
for num in range(100, 1000):
    # 将数字拆解成个位、十位、百位数字
    a = num // 100            # 百位
    b = (num // 10) % 10      # 十位
    c = num % 10              # 个位
    
    # 计算各位数字的立方和
    if a**3 + b**3 + c**3 == num:
        print(num)

JAVA 实现

import java.util.Scanner;
// 1:无需package
// 2: 类名必须Main, 不可修改

public class Main {
    public static void main(String[] args) {
        for (int num = 100; num < 1000; num++) {
            // 计算百位数字
            int a = num / 100;
            // 计算十位数字
            int b = (num / 10) % 10;
            // 计算个位数字
            int c = num % 10;

            // 计算各位数字的立方和并判断是否与原数字相等
            if (Math.pow(a, 3) + Math.pow(b, 3) + Math.pow(c, 3) == num) {
                System.out.println(num);
            }
        }
    }
}

C++ 实现

#include <iostream>
#include <cmath>
using namespace std;

int main() {
    for (int num = 100; num < 1000; num++) {
        // 计算百位数字
        int a = num / 100;
        // 计算十位数字
        int b = (num / 10) % 10;
        // 计算个位数字
        int c = num % 10;
        
        // 计算各位数字的立方和并判断是否与原数字相等
        if (pow(a, 3) + pow(b, 3) + pow(c, 3) == num) {
            cout << num << endl;
        }
    }
    
    return 0;
}

C 实现

#include <stdio.h>
#include <stdlib.h>
#include <math.h>

int main() {
    int num;
    for (num = 100; num < 1000; num++) {
        // 计算百位数字
        int a = num / 100;
        // 计算十位数字
        int b = (num / 10) % 10;
        // 计算个位数字
        int c = num % 10;
        
        // 计算各位数字的立方和并判断是否与原数字相等
        if (pow(a, 3) + pow(b, 3) + pow(c, 3) == num) {
            printf("%d\n", num);
        }
    }
    
    return 0;
}

运行结果

>>> 
153
370
371
407
>>> 

在这里插入图片描述


http://www.kler.cn/a/443627.html

相关文章:

  • AppAgent 源码 (xml 解析)
  • flask基础
  • Confluent Cloud Kafka 可观测性最佳实践
  • ES已死,文本检索永生
  • 使用 acme.sh 申请域名 SSL/TLS 证书完整指南
  • iLoveIMG:强大的在线图片编辑工具分享
  • SurfaceFlinger 学习
  • 使用DenyHosts阻止SSH暴力破解
  • Python 写的 《监控视频存储计算器》
  • HOOPS Communicator功能剖析:3D Web模型树交互的实用指南!
  • Hexo博客生成标签和分类页
  • 服务器ip:port服务用nginx 域名代理
  • 智能电网架构和模型:相关学点、工作模型、优势
  • Linux基础 -- 使用Linux Shell通过TCP发送消息
  • Spring框架中的@Async注解实现异步任务
  • websocket 局域网 webrtc 一对一 多对多 视频通话 的示例
  • Spring Boot中CollectionUtils怎么用
  • vscode 快速切换cangjie版本
  • 建投数据与腾讯云数据库TDSQL完成产品兼容性互认证
  • “AI应急管理系统:未来城市安全的守护者
  • 设计模式-总
  • Docker 容器中启用 SSH 服务
  • linux蓝牙模块和手机配对
  • AIA - 新增的CSR
  • Spring Boot 集成 MyBatis 全面讲解
  • PHPUnit使用指南:编写高效的单元测试