欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言 簡(jiǎn)單粗暴的笨方法找水仙花數(shù)

 更新時(shí)間:2022年02月11日 14:46:23   作者:i跑跑  
這篇文章介紹了C語(yǔ)言找水仙花數(shù)最原始的笨方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

什么是水仙花數(shù):

指一個(gè)n位數(shù),其各位數(shù)字的n次方之和確好等于該數(shù)本身

例如:? ?

1? ? ? ? ?1^1=1;

153? ? ? 3^3+5^3+1^3=153;

問(wèn)題:求0~100000之間的水仙花數(shù),并打印出來(lái)

看題目,找突破口:

  • 0~100000? 我可以想到用循環(huán)來(lái)判斷0~10000間的數(shù)字
  • 由栗子可知:我們需要求數(shù)字是幾位
  • 要用到次方,則我們需要引用math函數(shù)庫(kù)里的pow函數(shù)
  • 求和,依舊要使用循環(huán)

那么開始寫代碼,走一步思考一步:

#include <stdio.h>
#include <math.h>
 
int main()
{
	int i = 0;
	for (i = 0; i <= 100000; i++)
	{
		int n = 1;                // n 為位數(shù)
		int z = i;                //經(jīng)過(guò)while后i改變,i未變前賦值給z,代替原值i進(jìn)行后面的計(jì)算
		while (z / 10 != 0)          //這里剛開始直接用i進(jìn)行運(yùn)算  死循環(huán)
		{
			n++;
			z=z / 10;                //用i運(yùn)算的話,當(dāng)i=10時(shí) i=i/10 直接等于1 ,死循環(huán),所以用變量z代替i
		}
		if (i == Sum(i, n))        //判斷和是否等于原值
			printf("%d ",i);
	}
	return 0;
}

看代碼一定要看后面的注釋,這里要注意的點(diǎn):

用了n代表位數(shù),求n時(shí)while循環(huán)會(huì)改變i值,不利于后面的計(jì)算,所以用z代替

設(shè)置函數(shù)Sum來(lái)計(jì)算和,函數(shù)代碼如下:

int Sum(int x, int y)               //x接收i,y接收n
{
	int k = 0;
	int num = 0;
	int sum = 0;
	for (k=0;k<y;k++)             //循環(huán)求和
	{
		num = pow(x % 10, y);      //取出每一位的數(shù)字,求次方
		sum += num;                    //累加求和
		x/=10;                  //去掉最低位的數(shù)字
	}
	return sum;               //返回和
}

完整代碼如下:

#include <stdio.h>
#include <math.h>
 
int Sum(int x, int y)
{
	int k = 0;
	int num = 0;
	int sum = 0;
	for (k=0;k<y;k++)
	{
		num = pow(x % 10, y);
		sum += num;
		x/=10;
	}
	return sum;
}
 
int main()
{
	int i = 0;
	for (i = 0; i <= 100000; i++)
	{
		int n = 1;
		int z = i;
		while (z / 10 != 0)
		{
			n++;
			z=z / 10; 
		}
		if (i == Sum(i, n))
			printf("%d ",i);
	}
	return 0;
}

運(yùn)行結(jié)果:

這樣找水仙花數(shù)就完成了? ? ? ? ? ? ? ? ? ? ??

到此這篇關(guān)于C語(yǔ)言 簡(jiǎn)單粗暴的笨方法找水仙花數(shù)的文章就介紹到這了,更多相關(guān)C語(yǔ)言 找水仙花數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++二級(jí)指針和指針的引用

    C++二級(jí)指針和指針的引用

    這篇文章主要介紹了C++二級(jí)指針和指針的引用,下文舉例實(shí)現(xiàn)形參指針改變實(shí)參指針?biāo)赶虻膶?duì)象,需要的小伙伴可以參考一下,希望對(duì)你的學(xué)習(xí)有所幫助
    2022-03-03
  • C++類成員構(gòu)造函數(shù)和析構(gòu)函數(shù)順序示例詳細(xì)講解

    C++類成員構(gòu)造函數(shù)和析構(gòu)函數(shù)順序示例詳細(xì)講解

    這篇文章主要介紹了C++類成員構(gòu)造和析構(gòu)順序示例,看了這個(gè)例子大家就可以明白c++構(gòu)造析構(gòu)的奧秘
    2013-11-11
  • C++設(shè)計(jì)模式之解釋器模式

    C++設(shè)計(jì)模式之解釋器模式

    這篇文章主要介紹了C++設(shè)計(jì)模式之解釋器模式,本文講解了什么是解釋器模式、文法規(guī)則和抽象語(yǔ)法樹、解釋器模式的使用場(chǎng)合等內(nèi)容,需要的朋友可以參考下
    2014-10-10
  • c++調(diào)用windows鍵盤代碼詳情

    c++調(diào)用windows鍵盤代碼詳情

    c++調(diào)用windows鍵盤有好幾種方式,本文就根據(jù)列舉的例子對(duì)c++調(diào)用windows鍵盤詳細(xì)介紹并附上代碼說(shuō)明,需要的朋友可以參考下面文章的具體內(nèi)容
    2021-09-09
  • 深入淺析C++ traits技術(shù)

    深入淺析C++ traits技術(shù)

    traits就是提取“被傳進(jìn)的對(duì)象”對(duì)應(yīng)的返回類型,讓同一個(gè)接口實(shí)現(xiàn)對(duì)應(yīng)的功能。因?yàn)镾TL的算法和容器是分離的,兩者通過(guò)迭代器鏈接,本文通過(guò)實(shí)例代碼給大家介紹C++ traits技術(shù),感興趣的朋友一起看看吧
    2021-05-05
  • c語(yǔ)言中static的用法詳細(xì)示例分析

    c語(yǔ)言中static的用法詳細(xì)示例分析

    以下是對(duì)c語(yǔ)言中static函數(shù)的用法進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下
    2013-08-08
  • C語(yǔ)言使用鏈表實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)

    C語(yǔ)言使用鏈表實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言使用鏈表實(shí)現(xiàn)學(xué)生信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • C++面向?qū)ο笾袠?gòu)造函數(shù)使用詳解

    C++面向?qū)ο笾袠?gòu)造函數(shù)使用詳解

    學(xué)習(xí)過(guò)C語(yǔ)言的小伙伴知道:C語(yǔ)言是面向過(guò)程的,關(guān)注的是過(guò)程,分析出求解問(wèn)題的步驟,通過(guò)函數(shù)調(diào)用逐步解決問(wèn)題,這篇文章主要介紹了C++面向?qū)ο笾袠?gòu)造函數(shù)使用
    2022-10-10
  • C++按照正態(tài)分布來(lái)排列整型數(shù)組元素

    C++按照正態(tài)分布來(lái)排列整型數(shù)組元素

    這篇文章主要介紹了C++按照正態(tài)分布來(lái)排列整型數(shù)組元素的相關(guān)資料,需要的朋友可以參考下
    2016-07-07
  • C++類與對(duì)象深入之運(yùn)算符重載與const及初始化列表詳解

    C++類與對(duì)象深入之運(yùn)算符重載與const及初始化列表詳解

    運(yùn)算符是程序中最最常見的操作,例如對(duì)于內(nèi)置類型的賦值我們直接使用=賦值即可,因?yàn)檫@些編譯器已經(jīng)幫我們做好了,但是對(duì)象的賦值呢?能直接賦值嗎
    2022-06-06

最新評(píng)論