C语言深入探究水仙花数与变种水仙花数代码

 更新时间:2022年05月12日 14:16:29   作者:珠江上  
求水仙花数和变种水仙花数是非常适合初学者学习的代码,其中包含的循环和逻辑方式等知识点。这既能起到对以往知识的复习,也可以学习到一种不同的逻辑思考方式

1.水仙花

题目:

1.1先看代码

#include <stdio.h>
int main()
{
	int i = 0;
	int count = 0;
	for (i = 100; i<= 999; i++)
	{
		int a = i / 100;
		int b = (i % 100)/10;
		int c = (i % 100)%10;
		if (i == a * a * a + b * b * b + c * c * c)
		{
			printf("%d ", i);
			count++;
		}
	}
	printf("\ncount=%d\n", count);
	return 0;
}

1.2大体逻辑

a.题中说三位数中,因此第一步就要创建三位数100~999,最常用的方法就是 for()循环来创建

b. 153=1*1*1+5*5*5+3*3*3

求出 i 这个三位数中的百位、千位、个位;然后立方相加 判断 是否等于 i 就可以了

c.如何计算得出有多少个这样的数呢?在这里需要定义一个变量count专门来计算个数。如下

2.变种水仙花数

题目:

2.1先看代码

#include <stdio.h>
int main()
{
	int i = 0;
	for (i = 10000; i <= 99999; i++)
	{
		int j = 10;
		int sum = 0;
		int tmp = i;
		for (j = 10; j <= 10000; j *= 10)
		{
			sum += (tmp % j) * (tmp / j);
		}
		if (sum == i)
		{
			printf("%d ", i);
		}
	}
	return 0;
}

2.2代码剖析

a.题中说五位数中,因此第一步就要创建五位数10000~99999,还是用 for()循环来创建

b. 类似于

14610=1*4610+14*610+146*10+1461*0

14610/10000=1 14610%10000=4610

14610/1000=14 14610%1000=610

14610/100=146 14610%100=10

14610/10=1461 14610%10=0

看出逻辑了吗?用到循环来解

这串代码中:如果上面的 i 输入是16420,

sum=0 + (16420 % 10) * (16420 / 10) = 0*1642

sum=0 * 1642 + (16420 % 100) * (16420 / 100) = 0 * 1642 + 20 * 164

......

sum= 0 * 1642 + 20 *1 64 + 420 * 16 + 6420 * 1

一一列出就可以看出来循环的意思了

到此这篇关于C语言深入探究水仙花数与变种水仙花数代码的文章就介绍到这了,更多相关C语言水仙花数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C++设计模式之访问者模式

    C++设计模式之访问者模式

    这篇文章主要介绍了C++设计模式之访问者模式,本文讲解了什么是访问者模式、访问者模式的UML类图、访问者模式的实现代码等内容,需要的朋友可以参考下
    2014-10-10
  • C++最短路径Dijkstra算法的分析与具体实现详解

    C++最短路径Dijkstra算法的分析与具体实现详解

    经典的求解最短路径算法有这么几种:广度优先算法、Dijkstra算法、Floyd算法。本文是对 Dijkstra算法的总结,该算法适用于带权有向图,可求出起始顶点到其他任意顶点的最小代价以及对应路径,希望对大家有所帮助
    2023-03-03
  • 用C++编写扩展node.js(node-ffi版)

    用C++编写扩展node.js(node-ffi版)

    今天小编就为大家分享一篇关于用C++编写扩展node.js(node-ffi版),小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • C++ Primer 第一部分基本语言

    C++ Primer 第一部分基本语言

    这篇文章主要介绍了C++ Primer 第一部分基本语言的相关资料,需要的朋友可以参考下
    2014-02-02
  • C++文件的操作及小实验示例代码详解

    C++文件的操作及小实验示例代码详解

    这篇文章主要介绍了C++文件的操作及小实验,对于文件,它是一个流对象,对文件的操作无非是读和写,通过本文的学习大家将会理解文件的具体操作
    2022-05-05
  • 深入了解一下C语言中的柔性数组

    深入了解一下C语言中的柔性数组

    柔性数组是在C99中定义的,即结构体的最后一个元素允许是未知大小的数组,这就叫柔性数组。这篇文章将通过简单的示例为大家介绍一下柔性数组的使用,感兴趣的可以了解一下
    2023-02-02
  • C++中平衡二叉搜索树的模拟实现

    C++中平衡二叉搜索树的模拟实现

    二叉搜索树虽可以缩短查找的效率,但如果数据有序或接近有序二叉搜索树将退化为单支树,查找元素相当于在顺序表中搜索元素,效率低下,所以本文给大家介绍了C++平衡二叉的搜索树模拟实现方法,需要的朋友可以参考下
    2023-09-09
  • C语言数据结构之Hash散列表

    C语言数据结构之Hash散列表

    这篇文章主要介绍了C语言数据结构之Hash散列表,散列表(哈希表)其思想主要是基于数组支持按照下标随机访问数据,时间复杂度为O(1)的特性,可以说是数组的一种拓展,需要的朋友可以参考下
    2023-08-08
  • Cocos2d-x学习笔记之开发环境搭建

    Cocos2d-x学习笔记之开发环境搭建

    这篇文章主要介绍了Cocos2d-x学习笔记之开发环境搭建,本文使用Visual Studio作为开发IDE,是不同于其它教程的,需要的朋友可以参考下
    2014-09-09
  • C++报错:Id returned 1exit status的解决办法

    C++报错:Id returned 1exit status的解决办法

    最近刚学c语言,不止一次遇到了同一种报错,经过总结分享给大家,下面这篇文章主要给大家介绍了关于C++报错:Id returned 1exit status的解决办法,需要的朋友可以参考下
    2023-04-04

最新评论