题解 | #skew数#
skew数
https://www.nowcoder.com/practice/5928127cc6604129923346e955e75984
- !!审题要清楚,和二进制转换不同,不像二进制从0开始,我看半天没算出来,最后发现是审题问题。
- 大数运算,要转成字符串,用字符数组运算。
#include <iostream>
#include <string>
#include<math.h>
using namespace std;
int main() {
string str; //将输入存入字符串(避免大数溢出问题
while (cin >> str) { // 注意 while 处理多个 case
int sum = 0;
for (int i = 0; str[i] != '\0'; i++){
sum += (str[i]-'0') * (pow(2,str.size()-i)-1);
}
cout<<sum<<endl;
}
}
// 64 位输出请用 printf("%lld")


查看4道真题和解析