[問題] 請問我這題的邏輯哪裡錯了><
題目是寫一函式 : 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
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
04/09 02:02, 4F
→
04/09 02:04, , 5F
04/09 02:04, 5F
→
04/09 02:04, , 6F
04/09 02:04, 6F
→
04/09 02:05, , 7F
04/09 02:05, 7F
推
04/09 02:11, , 8F
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
04/09 06:16, 11F