作者spineless (金城好吃)
看板C_and_CPP
標題[問題] 請問我這題的邏輯哪裡錯了><
時間Thu Apr 9 01:52:40 2009
題目是寫一函式 : int SumOfDigit(int n);
若是n 為正整數 ,則函式回傳已十進位表示的所以位數的數字總合
例如輸入123 輸出為6 輸入1234 輸出為10
我原先的解法
/*輸入一整數 求出所有位數總合*/
#include<stdio.h>
int SumOfDigits(int);
int x,answer;
void main()
{
printf("input an integer\n");
scanf("%d",&x);
answer=SumOfDigits(x); //answer表示所有數字和
printf("the sum of the number is =%d\n",answer);
}
int SumOfDigits(int n)
{
int sum=0;
while (x/10 != 0)//表示商數大於等於10
{
n=x%10; //算出餘數 一值加總
sum+=n;
x=x/10;
printf("sum=%d\n",sum);
}
return sum;
}
我原本這樣解 則第一各數字永遠加總不到 例如輸入234 答案出來會等於7 不會是9
請問是我的while判斷式有問題嗎?那我該如何修改
後來嘗試另一種寫法
/*輸入一整數 求出所有位數總合*/
#include<stdio.h>
int SumOfDigits(int);
int x,answer;
void main()
{
printf("input an integer\n");
scanf("%d",&x);
answer=SumOfDigits(x);
printf("the sum of the number is =%d\n",answer);
}
int SumOfDigits(int n)
{
int sum=0; //
while (1)//表示商數大於等於10
{
n=x%10;
sum+=n;
x=x/10;
printf("sum=%d\n",sum);
if(x==0) //表示商為0 已經除到最後
break;
}
return sum;
}
這樣答案就對了 可是我覺得我考試的時候 只會想到第一種
第二種是靠complier才改的出來
請問我第一種寫法該如何修改呢
謝謝大家!!!!
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 220.139.42.183
1F:→ MOONRAKER:那就想辦法在考試的時候想到第二種啊 04/09 01:54
2F:推 ke60811:如果用陣列去存num%10的餘數(num=num/10) 再把他們相加呢? 04/09 01:56
3F:→ spineless:忘記補充 題目禁止用陣列 因為還沒教到>< 04/09 01:57
※ 編輯: spineless 來自: 220.139.42.183 (04/09 01:59)
4F:推 ke60811:把迴圈判斷式改while (x) 04/09 02:02
5F:→ ke60811:while (x/10 != 0)這樣寫當你數字為12時取餘數為2 12/10=1 04/09 02:04
6F:→ ke60811:1/10!=0 迴圈停止 所以第一位都不會加到 04/09 02:04
7F:→ spineless:ya! 可以了 謝謝樓上 我想好久>< 04/09 02:05
8F:推 VictorTom:while(x/10!=0)也行,只是while結束後再把x加上就好了吧? 04/09 02:11
9F:→ spineless:謝謝樓上 這樣也可以~!! 04/09 02:12
10F:推 ke60811:迴圈能一次跑完就讓他跑完咪 04/09 02:18
11F:推 springman:第一種將while(x/10!=0)改成while(x!=0)應該就可以 04/09 06:16