本程序已在Visual Studio 2008調(diào)試通過(guò)
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來(lái)自于我們對(duì)這個(gè)行業(yè)的熱愛(ài)。我們立志把好的技術(shù)通過(guò)有效、簡(jiǎn)單的方式提供給客戶,將通過(guò)不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:國(guó)際域名空間、網(wǎng)絡(luò)空間、營(yíng)銷軟件、網(wǎng)站建設(shè)、淮南網(wǎng)站維護(hù)、網(wǎng)站推廣。
#include "stdio.h"
int fun(int a[])//子函數(shù)中查找100~999之間的水仙花數(shù)
{int m,x,y,z,i=0;
for(m=100;m999;m++)
{x=m%10;//分解出個(gè)位數(shù)
y=(m-x)/10%10;//分解出十位數(shù)
z=m/100;//分解出百位數(shù)
if(x*x*x+y*y*y+z*z*z==m)//判斷每位數(shù)的立方的和是否與原數(shù)相等
{a[i]=m;i++;}}//若相等則存入數(shù)組
return(i);//返回?cái)?shù)組中水仙花數(shù)的個(gè)數(shù)以方便在主函數(shù)中輸出
}
void main()
{int fun(int a[]);//子函數(shù)先定義后使用
int a[20],i,k;
k=fun(a);//調(diào)用子函數(shù),注意本題中傳遞的是整個(gè)數(shù)組,所以子函數(shù)和主函數(shù)共用一個(gè)數(shù)組,系統(tǒng)分配的是同一片區(qū)域,雙向傳遞
for(i=0;ik;i++)//循環(huán)輸出
printf("%d=%d^3+%d^3+%d^3\n",a[i],a[i]/100,a[i]/10%10,a[i]%10);
}//輸出結(jié)果為 153=1^3+5^3+3^3 370=3^3+7^3+0^3 371=3^3+7^3+1^3 407=4^3+0^3+7^3
你看一下如果還有什么問(wèn)題再問(wèn)我
#includelt;stdio.hgt;
#includelt;math.hgt;
int narcissistic(int number);
void PrintN(int m,int n);
int main()
{
int m,n;
scanf("%d%d",m,n);
if(narcissistic(m))printf("%d is a narcissistic number\n",m);
PrintN(m,n);
if(narcissistic(n))printf("%d is a narcissistic number\n",n);
return 0;
}
int narcissistic(int number){
int i,n=0,sum=0,cnt=0;
n=number;
while(n){
cnt++;
n/=10;
}
n=number;
while(n){
i=n%10;
sum+=(int)pow(i,cnt);
n/=10;
}
if(sum==number)
return 1;
else
return 0;
}
void PrintN(int m,int n){
int i;
for(i=m+1;ilt;n;i++)
if(narcissistic(i))
printf("%d\n",i);
}
擴(kuò)展資料:
printf函數(shù)使用注意事項(xiàng)
1、域?qū)?/p>
%d:按整型數(shù)據(jù)的實(shí)際長(zhǎng)度輸出。
如果想輸出指定寬度可以指定域?qū)挘?md--gt,m域?qū)?,打印出?lái)以后,在控制臺(tái)上,顯示m位;
如果要打印的數(shù)的位數(shù)如果超過(guò)我們?cè)O(shè)定m則原樣輸出;
如果要打印的數(shù)的位數(shù)如果小于設(shè)定的位數(shù),則補(bǔ)空白,具體如下:
如果m為正數(shù),則左對(duì)齊(左側(cè)補(bǔ)空白);
如果m為負(fù)數(shù),則右對(duì)齊(右側(cè)補(bǔ)空白)。
2、轉(zhuǎn)義字符
如果想輸出字符"%",則應(yīng)該在“格式控制”字符串中用連續(xù)兩個(gè)%表示。
如:printf("%f%%",1.0/3);輸出結(jié)果:0.333333%。
參考資料:
百度百科——水仙花數(shù)
#include stdio.h
int main()
{
int start, end, i = 0, a, b, c, size = 0;
while (scanf("%d %d", start, end) == 2)
{
for (i = start; i = end; i++)
{
a = i / 100;
b = i / 10 % 10;
c = i % 10;
//total = pow(c, 3) + pow(a, 3) + pow(b, 3);
if ((a*a*a + b*b*b + c*c*c) == i)? //滿足水仙花條件
{
if (size == 0)? ?//size=0輸出第一個(gè)水仙花數(shù)
{
printf("%d", i);
}
else? ? ?//size++輸出第二。。第n個(gè)水仙花數(shù)
{
printf(" %d", i);
}
size++;? ?//個(gè)數(shù)++;
}
}
if (size == 0)? ?//范圍內(nèi)個(gè)數(shù)為0,則說(shuō)明沒(méi)有滿足條件的
{
printf("no");
}
printf("\n");
}
return 0;
}
擴(kuò)展資料:
需要注意的地方:
1.將n整除以100,得出n在百位上的數(shù)字hun。
2.將(n-i*100)整除以10(或?qū)先整除以10再對(duì)10求模n/10%10),得出n在十位上的數(shù)字ten。
3.將n對(duì)10取余,得出n在個(gè)位上的數(shù)字ind。
4.求得這三個(gè)數(shù)字的立方和是否與其本身相等,若相等,則該數(shù)為水仙花數(shù)。
參考資料:
百度百科-水仙花數(shù)
所謂的“水仙花數(shù)”是指一個(gè)三位數(shù)其各位數(shù)字的立方和等于該數(shù)本身,例如153是“水仙花數(shù)”,因?yàn)椋?53 = 1^3 + 5^3+ 3^3?。
下面是完整的C語(yǔ)言編程代碼:
運(yùn)行結(jié)果:
result is:153? 370? 371? 407
擴(kuò)展資料
常見(jiàn)水仙花數(shù)
水仙花數(shù)又稱阿姆斯特朗數(shù)。
1、三位的水仙花數(shù)共有4個(gè):153,370,371,407;
2、四位的四葉玫瑰數(shù)共有3個(gè):1634,8208,9474;
3、五位的五角星數(shù)共有3個(gè):54748,92727,93084;
4、六位的六合數(shù)只有1個(gè):548834;
5、七位的北斗七星數(shù)共有4個(gè):1741725,4210818,9800817,9926315;
6、八位的八仙數(shù)共有3個(gè):24678050,24678051,88593477
參考資料:百度百科:水仙花數(shù)