cracker_03 2021-10-05 22:19 采纳率: 82.6%
浏览 34
已结题

不知道哪错了,答案一直出错,求解。

Description

会长大人给出正整数N和M,变为二进制后,然后用前导0补全了32位。
N = 15,就是1111
N = 00000000000000000000000000001111
会长大人想对一些位置取反使得n变成m,最少需要几次操作?

Input

多组数据,对于每组数据:输入两个正整数N和M,用空格隔开,(N,M < 1e9)。

Output

对于每组数据输出一个整数表示答案。

Sample Input

10 35
6 6
Sample Output

3
0


#include<stdio.h>

void trans(int n,int* p)
{
    do
    {
        *p = n % 2;
        n /= 2;
        p--;
    } while (n>0);
}
int main()
{
    int N, M;
    while (scanf("%d %d", &N, &M)!=EOF)
    {
        int a[32] = { 0 }, b[32] = { 0 };
        int count = 0;
        trans(N,&a[32]);
        trans(M,&b[32]);
        for (int i = 0; i < 32; i++)
        {
            printf("%d ", a[i]);
        }
        printf("\n");
        for (int i = 0; i < 32; i++)
        {
            printf("%d ", b[i]);
        }
        for (int i = 0; i<32; i++)
        {
            if (a[i]==b[i])
            {
                count++;
            }
        }
        printf("%d\n", 32-count);
    }
    return 0;
}
  • 写回答

2条回答 默认 最新

  • 快乐鹦鹉 2021-10-05 22:32
    关注

    trans(N,&a[32]);
    trans(M,&b[32])
    改为
    trans(N,a);
    trans(M,b)

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 10月22日
  • 已采纳回答 10月14日
  • 修改了问题 10月10日
  • 修改了问题 10月5日
  • 展开全部

悬赏问题

  • ¥15 DS18B20内部ADC模数转换器
  • ¥15 做个有关计算的小程序
  • ¥15 MPI读取tif文件无法正常给各进程分配路径
  • ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
  • ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下
  • ¥15 setInterval 页面闪烁,怎么解决
  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动