當前位置:首頁 » 編程語言 » c語言水仙花代碼返回布爾值
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

c語言水仙花代碼返回布爾值

發布時間: 2022-07-16 21:52:41

1. c語言HDOJ2010水仙花數代碼求詳解

#include<stdio.h>
intmain()
{
intm,n,a,b,c,num;
while(scanf("%d%d",&m,&n)!=EOF)
{
num=0;
while(m<=n)
{
a=m/100;//取該三位數的百位,即123中的1(因為為int類型,所以123/100=1)
b=m/10%10;//取該三位數的十位,即123中的2(123/10=12,12%10=2)
c=m%10;//取該三位數的個位,即3(123%10=3)
if(m==a*a*a+b*b*b+c*c*c)//各個位上的數立方,判斷是否等於原三位數
{
num+=1;
if(num==1)
printf("%d",m);//注意最後一行不要多空格
else
printf("%d",m);//同上
}
m++;
}
if(num)
printf(" ");
elseprintf("no ");
}
return0;
}

2. 水仙花數c語言

C語言輸出水仙花數的具體分析和實現流程如下:

1、水仙花數的含義

「水仙花數」是一個三位數其各位數字的立方和等於該數本身。例如:3^3 + 7^3+ 0^3 = 370

2、演算法分析

把給出的某個三位數的個位、十位、百位分別拆分,並求其立方和(設為sum),若sum與給出的三位數相等, 則為「水仙花數」。

3、演算法設計

「水仙花數」是一個三位數,可以確定該數的取值范圍是 100〜999。對應的循環條件如下:

for (n=10; n<1000; n++) {}

(2)c語言水仙花代碼返回布爾值擴展閱讀:

常見水仙花數

水仙花數又稱阿姆斯特朗數。

1、三位的水仙花數共有4個:153,370,371,407;

2、四位的四葉玫瑰數共有3個:1634,8208,9474;

3、五位的五角星數共有3個:54748,92727,93084;

4、六位的六合數只有1個:548834;

5、七位的北斗七星數共有4個:1741725,4210818,9800817,9926315;

6、八位的八仙數共有3個:24678050,24678051,88593477

3. c語言編程:水仙花數

#include<stdio.h>
#include<stdilib.h>
main()
{
int i, a, b, c;
for( i=100; i<=999; i++ ){
c=i%100; //個位
a=i/100; //百位
b=i-100*a-c; //十位
if( a*a*a+b*b*b+c*c*c == i )
printf("%d\t",i);
}
system("pause");
return 0;
}

4. 「水仙花數」C語言程序

代碼如下:

#include <stdio.h>

int main()

{

printf("輸出水仙花數: ");

int i=100;

for( ; i<1000; i++){

int num_0 = i%10;

int num_1 = i/10%10;

int num_2 = i/10/10%10;

if(i==(num_0*num_0*num_0+num_1*num_1*num_1+num_2*num_2*num_2))

printf("%d ", i);

}

return 0;

}

(4)c語言水仙花代碼返回布爾值擴展閱讀

自冪數是指一個 n 位數,它的每個位上的數字的 n 次冪之和等於它本身。

n為1時,自冪數稱為獨身數。顯然,0,1,2,3,4,5,6,7,8,9都是自冪數。

n為2時,沒有自冪數。

n為3時,自冪數稱為水仙花數,有4個:153,370,371,407;

n為4時,自冪數稱為四葉玫瑰數,共有3個:1634,8208,9474;

n為5時,自冪數稱為五角星數,共有3個:54748,92727,93084;

n為6時,自冪數稱為六合數, 只有1個:548834;

n為7時,自冪數稱為北斗七星數, 共有4個:1741725,4210818,9800817,9926315;

n為8時,自冪數稱為八仙數, 共有3個:24678050,24678051,88593477;

n為9時,自冪數稱為九九重陽數,共有4個:146511208,472335975,534494836,912985153;

n為10時,自冪數稱為十全十美數,只有1個:4679307774。

5. C語言新手求助,兩段求水仙花數的代碼,結果卻不一樣

第二段代碼的判斷語句,使用的函數double pow(double, double)其參數值和函數返回值,都是雙精度浮點。,雙精度浮點進行邏輯判斷時,會存在精度誤差,導致結果不完全准確,可將這句修改如下:

if(floor(pow(a,3)+pow(b,3)+pow(c,3)+0.5)==num)printf("%d
",num);
這樣就能保證等號兩邊的值不會因為double的誤差導致錯誤結果。

如滿意,歡迎採納,謝謝
如有疑問,歡迎追問

6. 水仙花數的c語言編程。

C語言具體實現水仙花過程如下:

一、問題描述:

輸出所有的「水仙花數」,所謂的「水仙花數」是指一個三位數其各位數字的立方和等於該數本身,例如153是「水仙花數」,因為:153 = 13 + 53 + 33。

二、問題分析:

根據「水仙花數」的定義,判斷一個數是否為「水仙花數」,最重要的是要把給出的三位數的個位、十位、百位分別拆分,並求其立方和(設為s),若s與給出的三位數相等, 三位數為「水仙花數」,反之,則不是。

三、演算法設計:

「水仙花數」是指滿足某一條件的三位數,根據這一信息可以確定整數的取值范圍是 100〜999。對應的循環條件如下:

for(n=10; n<1000; n++) { //...... }

四、完整的代碼:

7. C語言編寫水仙花數

#include<stdio.h>
void main()
{
long int m,s,n; /*定義長整形數字:m,s,n,m存放判斷的數字,s存放各位數字之和,n存放中間數字*/
int p; /*定義整形數字,來存放每個位的數字*/
printf("請輸入一個整數:");
scanf("%ld",&m);/*輸入長整形數字*/
s=0; /*賦予s值為0*/
p=m%10; /*求得m的第一位數字,從各位開始*/
s+=p*p*p;
n=m/10; /*把m數字的第一位去掉,直接除以10*/
while(n!=0) /*當n不等於0時*/
{ p=n%10; /*求的每一位數字*/
s+=p*p*p; /*繼續求和*/
n=n/10; } /*繼續依次去掉每一位數字*/
if(s==m) printf("是水仙花數\n"); /*最後,如果求得的和等於m,則為水仙花數*/
else printf("不是水仙花數\n");
}
/* PS:上述代碼,是輸入一個數字,判斷是否是水仙花數,如果,想求其他的,可把上述代碼移植到其他程序中。經測試,可以使用。*/
/*PS::::如還有不懂,可繼續*/