http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=100&page=show_problem&problem=516
题意:
输入数字s,类似输出N进制,稍许不同。
解题:
水题。不过有个坏习惯,老是直接对行直接用int/long之类接收数据,容易导致后续数据处理问题。
用字符串保留最初的数据,最佳。
另,cmath的pow好难用,还不如自己写一个,抄别人的~
#include <iostream>
#include <string>
#include <stdio.h>
using namespace std;
// #define LOCAL_TEST
int pow(int n)
{
int i, s = 1;
for ( i=1; i<=n; i++ )
s = s*2;
return s;
}
int main()
{
#ifdef LOCAL_TEST
freopen("f:\\in.txt", "r", stdin);
freopen("f:\\out.txt", "w+", stdout);
#endif
char s[100];
int l, num;
while ( gets(s) )
{
string str(s);
l = str.length();
num = 0;
if (s[0]=='0' && l==1)
break;
for (int i=0; i<l; i++)
num += (s[i]-'0')*(pow(l-i)-1);
cout <<num <<'\n';
} // end while
return 0;
}