❶ c語言,輸出水仙花數。輸入3<=n<=7,輸出所有的n位水仙花數。 為什麼 我運行時 輸入n然後回車之後 沒反應
while(h!=0)?
你的h都沒有初始化,它不等於0等於啥呀?直接就果斷退出了。你這是跟你的程序開玩笑呢,它當然啥也不給你輸出了
❷ 「水仙花數」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;
}
(2)水仙花數c語言3都7位擴展閱讀:
自冪數是指一個 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。
❸ C語言,輸出水仙花數。輸入3<=n<=7,輸出所有的n位水仙花數。 為什麼 我運行時 輸入n然後回車之後 沒反應
#include<stdio.h>
intpower(intx,inty)//不要用pow當函數名,因為math.h里有pow的系統函數,會有歧義
{
inti=1,a=1;
while(i<=y)
{
a=a*x;
i++;
}
returna;
}
intmain(void)
{
inti,h,n,s,m=0,b;
printf("輸入n位數字(3<=n<=7)");
scanf("%d",&n);
for(s=power(10,n-1);s<power(10,n);s++)
{
b=s;//循環不要改變s的值,因為最後還要s++
//之前的程序改變了s的值,所以執行完100的判斷後,s=1,沒法繼續下面的
m=0;//m每累加完一個數的記得清零
for(i=1;i<=n;i++)
{
h=b%10;//每次改變b的值
m=m+power(h,n);
b=b/10;
}
if(m==s)printf("%d ",m);//用s去比較
}
return0;
}
❹ c語言求水仙花數!!!!
#include"stdio.h"
intmain(intargc,char*argv[]){
intn,i,j,k,t,s,m,x;
printf("Pleaseentern(int2<n<8)... n=");
if(scanf("%d",&n)!=1||n<3||n>7){
printf("Inputerror,exit... ");
return0;
}
for(k=1,i=0;i<n;i++,k*=10);
for(i=k/10;i<k;i++){
for(s=0,t=i;t>0;t/=10){
for(x=1,j=t%10,m=n;m--;x*=j);
s+=x;
}
if(s==i)
printf("%d ",s);
}
printf(" ");
return0;
}
運行樣例:
❺ C語言求3-7位數的水仙花數程序改錯
你的程序主要問題是pow函數返回的是double類型的數,需要強制轉換成long型整數,
sum每計算完一個數要重置為0,還有就是輸出語句printf函數的變數不需要取地址符.
改完的程序如下(見圖,改動的地方見注釋)
❻ C語言的水仙花數,怎麼搞
#include<stdio.h>
#include<math.h>
int main() {
int N,i,sum,n;
scanf("%d",&N);//輸入
for(i=pow(10,N-1);i<pow(10,N);i++)//N是幾位數,循環就從10的N-1次方至N次方,比如說N為3,那就是10的2次方(100)至10的3次方(1000)
{
sum=0;
n=i;
while(n)
{
sum+=pow(n%10,N);//計算每一位的N次方的和至sum
n=n/10;
}
if(sum==i) printf("%d\n",i);//比較和是否與原數i相等,如果相等則為水仙花數並輸出
}
}
❼ 水仙花數的c語言編程。
C語言具體實現水仙花過程如下:
一、問題描述:
輸出所有的「水仙花數」,所謂的「水仙花數」是指一個三位數其各位數字的立方和等於該數本身,例如153是「水仙花數」,因為:153 = 13 + 53 + 33。
二、問題分析:
根據「水仙花數」的定義,判斷一個數是否為「水仙花數」,最重要的是要把給出的三位數的個位、十位、百位分別拆分,並求其立方和(設為s),若s與給出的三位數相等, 三位數為「水仙花數」,反之,則不是。
三、演算法設計:
「水仙花數」是指滿足某一條件的三位數,根據這一信息可以確定整數的取值范圍是 100〜999。對應的循環條件如下:
for(n=10; n<1000; n++) { //...... }
四、完整的代碼:
❽ 輸出三位到七位所有的水仙花數
# include <stdio.h>
void main()
{
int i,j,k,n;
printf("水仙花數: ");
for (n=100; n<1000; n++)
{
i=n/100;
j=(n-i*100)/10;
k=n%10;
if(i*i*i+j*j*j+k*k*k==n)
{
printf("%d ",n);
}
}
}
編程界面和輸出結果: