NeQrhk 2015-07-16 23:03 采纳率: 30.6%
浏览 2223

一个c语言的简单acm问题,求两个二进制数有多少位不同,输入的是十进制数.

include
int main()
{
int n,p=0,k,m,t;
int a[50];
int b[50];
int c[50];
int d[50];
int i=0,j,u,z,w,q,e,s;
int r;
int count=0;
scanf("%d",&r);
while(r--){
scanf("%d%d",&n,&m);
while(n>0)
{
j=n%2;
n=n/2;
a[i++]=j;
}
while(m>0)
{
k=m%2;
m=m/2;
b[p++]=k;
}
if(i>p){
for(q=i-1,u=0;q>=0;q--,u++)
c[q]=a[u];
for(z=p+(i-p)-1,u=0;z>=i-p;u++,z--)//先从右往左填充d数组,前面留下的空位置置0
d[z]=b[u];
for(e=0;e d[e]=0;
for(w=0;w if(c[w]!=d[w])
count++;
}
else if(i

{
for(q=p-1,u=0;q>=0;q--,u++)
c[q]=b[u];
for(z=i+(p-i)-1,u=0;z>=p-i;u++,z--)//同上
d[z]=a[u];
for(e=0;e<p-i;e++)
d[e]=0;
for(w=0;w<p;w++)
if(c[w]!=d[w])
count++;
}
else{
for(q=0;q<i;q++)
if(a[q]!=b[q])
count++;
}
printf("%d",count);
}
return 0;
}

http://swun.openjudge.cn/practice/1009/题目在这里
我的代码出来结果一样怎么会没办法AC

  • 写回答

6条回答 默认 最新

  • leizhang250 2015-07-17 00:12
    关注

    看看。最后一句没明白啊?

    评论

报告相同问题?

悬赏问题

  • ¥100 求数学坐标画圆以及直线的算法
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站