输入样例:2x1213s4s60340a5102304511
输出样例:110010011:403
备注:只考虑无符号整数,即不考虑负数补码的问题,过滤下来的二进制数一律按无符号整数处理即可
本人小白,学习没多久,这个题不太会做了,不知道怎么
不好意思,上面写错了一点
char p[] = "2x1213s4s60340a5102304511";
int j = 0;
for (int i = 0; i<strlen(p); i++)
{
if (p[i] == '0' || p[i] == '1')
{
p[j] = p[i];
j++;
}
}
p[j] = 0;
UINT uVal = 0;
UINT d = 1;
for (int i = strlen(p) - 1; i >= 0; i--)
{
if (p[i] == '1')
uVal += d;
d = d * 2;
}
这样最后uVal就是403了
用循环语句把1和0放到一个新的数组中,然后根据公式:序数*2的n减-1次方相加。
万一80个都是0和1组成的,这个数得多大啊
char p[] = "2x1213s4s60340a5102304511";
int j = 0;
for(int i=0; i<strlen(p);i++)
{
if(p[i] == '0' || p[i] == '1')
{
p[j] = p[i];
j++;
}
p[j] = 0;
}
UINT uVal = 0;
UINT d = 1;
for(int i=strlen(p)-1; i>=0;i--)
{
if(p[i] == 1)
uVal += d;
d = d*2;
}
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int main()
{
char ch,s[80];
int i=0,x=0;
double y=0,j=0;
while((ch=getchar())!='\n')
{
if(ch=='0')
{
s[i]=ch;
i++;
x=x*10+0;
}
if(ch=='1')
{
s[i]=ch;
i++;
x=x*10+1;
}
}
s[i]='\0';
while(x!=0)
{
y+=(x%10)*pow(2,j);
j++;
x=x/10;
}
printf("%s:%.0f",s,y);
return 0;
}
您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~
如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~
ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632
非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!
速戳参与调研>>>https://t.csdnimg.cn/Kf0y