[問題] 請問我這題的邏輯哪裡錯了><

看板C_and_CPP作者 (金城好吃)時間15年前 (2009/04/09 01:52), 編輯推噓5(506)
留言11則, 5人參與, 最新討論串1/1
題目是寫一函式 : 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

04/09 01:54, , 1F
那就想辦法在考試的時候想到第二種啊
04/09 01:54, 1F

04/09 01:56, , 2F
如果用陣列去存num%10的餘數(num=num/10) 再把他們相加呢?
04/09 01:56, 2F

04/09 01:57, , 3F
忘記補充 題目禁止用陣列 因為還沒教到><
04/09 01:57, 3F
※ 編輯: spineless 來自: 220.139.42.183 (04/09 01:59)

04/09 02:02, , 4F
把迴圈判斷式改while (x)
04/09 02:02, 4F

04/09 02:04, , 5F
while (x/10 != 0)這樣寫當你數字為12時取餘數為2 12/10=1
04/09 02:04, 5F

04/09 02:04, , 6F
1/10!=0 迴圈停止 所以第一位都不會加到
04/09 02:04, 6F

04/09 02:05, , 7F
ya! 可以了 謝謝樓上 我想好久><
04/09 02:05, 7F

04/09 02:11, , 8F
while(x/10!=0)也行,只是while結束後再把x加上就好了吧?
04/09 02:11, 8F

04/09 02:12, , 9F
謝謝樓上 這樣也可以~!!
04/09 02:12, 9F

04/09 02:18, , 10F
迴圈能一次跑完就讓他跑完咪
04/09 02:18, 10F

04/09 06:16, , 11F
第一種將while(x/10!=0)改成while(x!=0)應該就可以
04/09 06:16, 11F
文章代碼(AID): #19tEHhw7 (C_and_CPP)