qq_18147713 2021-12-16 12:40 采纳率: 73.8%
浏览 57
已结题

C语言编程问题求解答

题目描述
最近小晨在计概课上学习到二进制之后对其产生了浓厚的兴趣,在每次操作仅能移动相邻的0和1的前提下,她想知道把一个二进制数转换成另一个二进制数的最小操作数。

关于输入
输入共三行:

第一行为一个整数n (0 < n <= 200),代表二进制数的位数

第二行为第一个二进制数的每一位

第三行为第二个二进制数的每一位

关于输出
输出将第一个二进制数转换为第二个二进制数的最少操作数,如果答案不存在,则输出-1

例子输入
7
1 1 0 1 0 0 1
0 1 1 0 0 1 1
例子输出
4

  • 写回答

2条回答 默认 最新

  • panfei625 2021-12-16 12:41
    关注
    
    #include<stdio.h>
    int main()
    {
        int n = 0;
        int a[200] = { 0 };
        int b[200] = { 0 };
    int a0=0;
    int b0=0;
        scanf("%d", &n);
        for (int i = 0; i < n; i++) {
            scanf("%d", &a[i]);
    if (a[i] == 0)a0++;
        }
        for (int i = 0; i < n; i++) {
            scanf("%d", &b[i]);
    if(b[i]==0)b0++;
        }
        int cnt = 0;
    if(a0!=b0)printf("-1");
    else{
        for (int i = 0; i < n; i++) {
            if(a[i]!=b[i]){
                for (int j = i + 1; j < n; j++) {
                    if (a[j] == b[i]) {
                        for (int p = j-1; p >= i; p--) {
                            int temp = 0;
                            temp = a[p];
                            a[p] = a[p + 1];
                            a[p + 1] = temp;
                            cnt++;
                        }
                    
                        break;
                    }
                            
                }
            } 
    
        }
        
        printf("%d", cnt);
    }
        
            return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 12月24日
  • 已采纳回答 12月16日
  • 创建了问题 12月16日

悬赏问题

  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改