【华为机试】2023年真题B卷(python)-出错的或电路

一、题目

题目描述:

某生产门电路的厂商发现某一批次的或门电路不稳定,具体现象为计算两个二进制数的或操作时,第一个二进制数中某两个比特位会出现交换, 交换的比特位置是随机的,但只交换这两个位,其他位不变。

很明显,这个交换可能会影响最终的或结果,也可能不会有影响。

为了评估影响和定位出错的根因,工程师需要研究在各种交换的可能下,最终的或结果发生改变的情况有多少种。

二、输入输出

输入描述:

第一行有一个正整数N;其中1≤N≤1000000。 第二行有一个长为N的二进制数,表示与电路的第一个输入数,即会发生比特交换的输入数。 第三行有一个长为N的二进制数,表示与电路的第二个输入数。注意第二个输入数不会发生比特交换。
输出描述:

输出只有一个整数,表示会影响或结果的交换方案个数。

三、示例

示例1

输入输出示例仅供调试,后台判题数据一般不包含示例

输入:

3

010

110

输出:

1

说明:

原本010和110的或结果是110,但第一个输入数可能会发生如下三种交换:

1.交换第1个比特和第2个比特,第一个输入数变为100,计算结果为110,计算结果不变

2.交换第1个比特和第3个比特,第一个输入数变为010,计算结果为110,计算结果不变

3.交换第2个比特和第3个比特,第一个输入数变为001,计算结果为111,计算结果改变 故只有一种交换会改变计算结果。

四、要求

时间限制:C/C++ 1秒,其他语言 2秒

空间限制:C/C++262144K,其他语言524288K

64bit IO Format:%lld

五、解题思路

1:明显同数字之间的交换不会产生影响,所以就是0和1之间的交换。

2:因为要与第二次输入的数进行或计算,那么如果第二次输入的数的其中一位只要是1,那么不管第一次输入有没有发生交换,或结果都是1。所以第二次输入的当该位为0的时候,第一次输入的交换才有意义。

六、参考代码

python 复制代码
# -*- coding: utf-8 -*-
'''
@File    :   2023-B-出错的或电路.py
@Time    :   2023/12/10 00:09:00
@Author  :   mgc 
@Version :   1.0
@Desc    :   None
'''

import os
import sys
import re
import re

n = int(input())

a = input()
b = input()
c = []
cnt = [0] * 2
for i in range(n):
    if b[i] == '0':
        c.append(int(a[i]))
    if a[i] == '0':
        cnt[0] += 1
    else:
        cnt[1] += 1
total = 0

for i in range(len(c)):
    total += cnt[c[i] ^ 1]
    cnt[c[i]] -= 1

print(total)
相关推荐
XiaoMu_00112 分钟前
基于Django+Vue3+YOLO的智能气象检测系统
python·yolo·django
superlls1 小时前
(算法 哈希表)【LeetCode 349】两个数组的交集 思路笔记自留
java·数据结构·算法
honder试试1 小时前
焊接自动化测试平台图像处理分析-模型训练推理
开发语言·python
田里的水稻1 小时前
C++_队列编码实例,从末端添加对象,同时把头部的对象剔除掉,中的队列长度为设置长度NUM_OBJ
java·c++·算法
心本无晴.1 小时前
Python进程,线程
python·进程
纪元A梦2 小时前
贪心算法应用:保险理赔调度问题详解
算法·贪心算法
Jayden_Ruan2 小时前
C++逆向输出一个字符串(三)
开发语言·c++·算法
爱笑的眼睛113 小时前
HarmonyOS 应用开发新范式:深入剖析 Stage 模型与 ArkTS 状态管理
华为·harmonyos
点云SLAM3 小时前
C++ 常见面试题汇总
java·开发语言·c++·算法·面试·内存管理
叙白冲冲3 小时前
哈希算法以及面试答法
算法·面试·哈希算法