如题所述
while前加一句if(x==0) i=1;
另外建议用字符串做
因为可能有很多位 例如1000位
另外建议用字符串做
因为可能有很多位 例如1000位
温馨提示:答案为网友推荐,仅供参考
第1个回答 2013-04-21
#include <iostream>
#include <string>
using namespace std;
int main()
{
string strInput;
cin >> strInput;
cout << strInput.length();
return 0;
}追问
#include <string>
using namespace std;
int main()
{
string strInput;
cin >> strInput;
cout << strInput.length();
return 0;
}追问
#include
void main()
{
int x,y,i=1;
scanf("%d",&x);
while(x>0)
{
y=x%10;
x=x/10;
i++;
}printf("%d\n",i);
}
这是我写的,问题就是输入0的时候,输出也是0.而正确应该是1.在这个基础上怎么改进啊
scanf将输入变成数值来算的话是会有问题的,当数值非常大的时候就会有问题
你那个代码初始值i已经等于1了吧,即使不进入循环也会输出1位的