当前位置: 首页 > news >正文

自学设计软件的免费网站推广普通话手抄报简单漂亮

自学设计软件的免费网站,推广普通话手抄报简单漂亮,高端html5网站建设织梦模板,江西省赣州市中考成绩查询时间文章目录 题目描述与示例题目描述输入描述输出描述示例一输入输出说明 示例二输入输出说明 解题思路代码PythonJavaC时空复杂度 华为OD算法/大厂面试高频题算法练习冲刺训练 题目描述与示例 题目描述 某生产门电路的厂商发现某一批次的或门电路不稳定,具体现象为计…

文章目录

  • 题目描述与示例
    • 题目描述
    • 输入描述
    • 输出描述
    • 示例一
      • 输入
      • 输出
      • 说明
    • 示例二
      • 输入
      • 输出
      • 说明
  • 解题思路
  • 代码
    • Python
    • Java
    • C++
    • 时空复杂度
  • 华为OD算法/大厂面试高频题算法练习冲刺训练

题目描述与示例

题目描述

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

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

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

输入描述

第一行有一个正整数 N;其中 1 ≤ N ≤ 1000000

第二行有一个长为 N 的二进制数,表示与电路的第一个输入数,即会发生比特交换的输入数。

第三行有一个长为 N 的二进制数,表示与电路的第二个输入数。注意第二个输入数不会发生比特交换。

输出描述

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

示例一

输入

3
010
110

输出

1

说明

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

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

故只有一种交换会改变计算结果。

示例二

输入

6
011011
110110

输出

4

说明

原本 011011110110 的或结果是 111111,但第一个输入数发生如下比特交换会影响最终计算结果:

  1. 交换第 1 个比特和第 3 个比特,第一个输入数变为 110011,计算结果变为 110111
  2. 交换第 1 个比特和第 6 个比特,第一个输入数变为 111010,计算结果变为 111110
  3. 交换第 3 个比特和第 4 个比特,第一个输入数变为 010111,计算结果变为 110111
  4. 交换第 4 个比特和第 6 个比特,第一个输入数变为 011110,计算结果变为 111110

其他的交换都不会影响计算结果,故输出 4

解题思路

第一个二进制数我们记为num1,第二个二进制数我们记为num2,或运算的结果记为num_or。对num1所选取的两个位置记为ij

如果num1[i]num1[j]交换之后或运算的结果和之前的不一致,说明交换的两个位置必定满足以下条件:

  1. num1[i] != num1[j],即交换的两个数必须是一个0一个1,不能均为0或者均为1。因为如果num1[i] == num1[j],说明交换前后的num1是一致的,与num2进行位运算得到的结果的num_or自然也是一致的。
  2. num2[i]num2[j]不能均为1,即num2的对应位置,至少有存在10。因为如果存在num2[i] == num2[j] == 1,那么无论num1[i]num1[j]是什么内容,或运算的结果一定存在num_or[i] == num_or[j] == 1,不会因为num1[i]num1[j]的交换而改变。

简单来说:

  1. num1的两个位置必须是一个0和一个1
  2. num2的两个位置必须至少有一个0

因此,如果num_or在交换前后出现改变,那么只可能是以下三种情况。

num1的情况num2的情况num_or交换前num_or交换后
num1[i] = 1``num1[j] = 0num2[i] = 0``num2[j] = 0num1[i] = 1``num1[j] = 0num1[i] = 0``num1[j] = 1
num1[i] = 1``num1[j] = 0num2[i] = 1``num2[j] = 0num1[i] = 1``num1[j] = 0num1[i] = 1``num1[j] = 1
num1[i] = 1``num1[j] = 0num2[i] = 0``num2[j] = 1num1[i] = 1``num1[j] = 1num1[i] = 0``num1[j] = 1

由于ij两者的地位是等价的,因此我们只需要求出以下四种情况下的索引i的个数

  1. num1[i] == 1num2[i] == 1i的个数,记为cnt11
  2. num1[i] == 0num2[i] == 0i的个数,记为cnt00
  3. num1[i] == 1num2[i] == 0i的个数,记为cnt10
  4. num1[i] == 0num2[i] == 1i的个数,记为cnt01

上述表格中的三种情况的个数,根据乘法原理,分别对应

  • cnt10 * cnt00
  • cnt11 * cnt00
  • cnt10 * cnt01

再将上述三者的结果相加,即为答案。

代码

Python

# 题目:2023B-出错的或电路
# 分值:200
# 作者:闭着眼睛学数理化
# 算法:数学/乘法原理
# 代码看不懂的地方,请直接在群上提问n = int(input())
num1 = input()
num2 = input()# 初始化四个变量,分别统计四种情况
cnt11, cnt00, cnt10, cnt01 = 0, 0, 0, 0
for i in range(n):# 分别根据num1[i]和num2[i]的情况# 统计对应变量的个数if num1[i] == "1" and num2[i] == "1":cnt11 += 1elif num1[i] == "0" and num2[i] == "0":cnt00 += 1elif num1[i] == "1" and num2[i] == "0":cnt10 += 1elif num1[i] == "0" and num2[i] == "1":cnt01 += 1# 根据乘法原理,进行计算
ans = cnt10 * cnt00 + cnt11 * cnt00 + cnt10 * cnt01
print(ans)

Java

import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();String num1 = scanner.next();String num2 = scanner.next();int cnt11 = 0, cnt00 = 0, cnt10 = 0, cnt01 = 0;for (int i = 0; i < n; i++) {if (num1.charAt(i) == '1' && num2.charAt(i) == '1') {cnt11++;} else if (num1.charAt(i) == '0' && num2.charAt(i) == '0') {cnt00++;} else if (num1.charAt(i) == '1' && num2.charAt(i) == '0') {cnt10++;} else if (num1.charAt(i) == '0' && num2.charAt(i) == '1') {cnt01++;}}int ans = cnt10 * cnt00 + cnt11 * cnt00 + cnt10 * cnt01;System.out.println(ans);}
}

C++

#include <iostream>
using namespace std;int main() {int n;cin >> n;string num1, num2;cin >> num1 >> num2;int cnt11 = 0, cnt00 = 0, cnt10 = 0, cnt01 = 0;for (int i = 0; i < n; i++) {if (num1[i] == '1' && num2[i] == '1') {cnt11++;} else if (num1[i] == '0' && num2[i] == '0') {cnt00++;} else if (num1[i] == '1' && num2[i] == '0') {cnt10++;} else if (num1[i] == '0' && num2[i] == '1') {cnt01++;}}int ans = cnt10 * cnt00 + cnt11 * cnt00 + cnt10 * cnt01;cout << ans << endl;return 0;
}

时空复杂度

时间复杂度:O(N)。一次遍历求出四个变量的情况。

空间复杂度:O(1)。仅需若干常数变量


华为OD算法/大厂面试高频题算法练习冲刺训练

  • 华为OD算法/大厂面试高频题算法冲刺训练目前开始常态化报名!目前已服务100+同学成功上岸!

  • 课程讲师为全网50w+粉丝编程博主@吴师兄学算法 以及小红书头部编程博主@闭着眼睛学数理化

  • 每期人数维持在20人内,保证能够最大限度地满足到每一个同学的需求,达到和1v1同样的学习效果!

  • 60+天陪伴式学习,40+直播课时,300+动画图解视频,300+LeetCode经典题,200+华为OD真题/大厂真题,还有简历修改、模拟面试、专属HR对接将为你解锁

  • 可上全网独家的欧弟OJ系统练习华子OD、大厂真题

  • 可查看链接 大厂真题汇总 & OD真题汇总(持续更新)

  • 绿色聊天软件戳 od1336了解更多


文章转载自:
http://wanjiasley.gthc.cn
http://wanjiaadjustive.gthc.cn
http://wanjiarepetend.gthc.cn
http://wanjiadeictic.gthc.cn
http://wanjiaostend.gthc.cn
http://wanjiainverseimage.gthc.cn
http://wanjiasugariness.gthc.cn
http://wanjiafootstool.gthc.cn
http://wanjiaobsolete.gthc.cn
http://wanjiahemispheroid.gthc.cn
http://wanjianotturno.gthc.cn
http://wanjiacapture.gthc.cn
http://wanjiachad.gthc.cn
http://wanjiaheterocaryosis.gthc.cn
http://wanjiabiocytin.gthc.cn
http://wanjiadisoperative.gthc.cn
http://wanjialacquer.gthc.cn
http://wanjiatrijugate.gthc.cn
http://wanjiaadhibition.gthc.cn
http://wanjialiturgics.gthc.cn
http://wanjiaimpalpably.gthc.cn
http://wanjiafuturologist.gthc.cn
http://wanjiatchotchke.gthc.cn
http://wanjiaglycosuria.gthc.cn
http://wanjiatoolmaking.gthc.cn
http://wanjiapenoncel.gthc.cn
http://wanjiabastaard.gthc.cn
http://wanjiaphosphoresce.gthc.cn
http://wanjiacongenial.gthc.cn
http://wanjiaarrenotokous.gthc.cn
http://wanjiaisooctane.gthc.cn
http://wanjiagip.gthc.cn
http://wanjiaknotty.gthc.cn
http://wanjiaculturist.gthc.cn
http://wanjiasukiyaki.gthc.cn
http://wanjiadestructibility.gthc.cn
http://wanjiafrey.gthc.cn
http://wanjiafacetiae.gthc.cn
http://wanjiadreamfully.gthc.cn
http://wanjiaballiol.gthc.cn
http://wanjiabiomorphic.gthc.cn
http://wanjiaajiva.gthc.cn
http://wanjiainter.gthc.cn
http://wanjiaastronome.gthc.cn
http://wanjiaapothecary.gthc.cn
http://wanjiagaga.gthc.cn
http://wanjiacorny.gthc.cn
http://wanjiabistate.gthc.cn
http://wanjiasmoggy.gthc.cn
http://wanjiaracquetball.gthc.cn
http://wanjianazir.gthc.cn
http://wanjiakentledge.gthc.cn
http://wanjiahydrazide.gthc.cn
http://wanjiaunhand.gthc.cn
http://wanjiaappulsive.gthc.cn
http://wanjiaunfelt.gthc.cn
http://wanjiawindscreen.gthc.cn
http://wanjiacomprise.gthc.cn
http://wanjiaemesis.gthc.cn
http://wanjiaastoundment.gthc.cn
http://wanjiadocking.gthc.cn
http://wanjiabireme.gthc.cn
http://wanjiainfuriate.gthc.cn
http://wanjiacmos.gthc.cn
http://wanjiaregula.gthc.cn
http://wanjianonintercourse.gthc.cn
http://wanjiacoxitis.gthc.cn
http://wanjiaromany.gthc.cn
http://wanjiamyelogenous.gthc.cn
http://wanjiaaesthesia.gthc.cn
http://wanjiaamoebic.gthc.cn
http://wanjiabarytes.gthc.cn
http://wanjiasaute.gthc.cn
http://wanjiawainage.gthc.cn
http://wanjiaastrospace.gthc.cn
http://wanjiastripe.gthc.cn
http://wanjiasantiago.gthc.cn
http://wanjiaethogram.gthc.cn
http://wanjiacancer.gthc.cn
http://wanjiapeahen.gthc.cn
http://www.15wanjia.com/news/117179.html

相关文章:

  • 网站建设广州白云二级域名网站查询入口
  • 自己做企业网站用哪个软件北京本地网络推广平台
  • 网站开发人员的要求百度联盟推广
  • 阿里巴巴批发网站叫什么seo优化推广
  • 公司做网站的意义百度营销网页版
  • 网站运营怎么样免费的网页模板网站
  • 提升网站流量该怎么做新站快速收录
  • 公司简介链接怎么制作网络营销郑州优化推广公司
  • 男人最爱的做网站最有效的恶意点击
  • 中山金舜家庭用品有限公司怎样网站地图深圳网站制作
  • 公司网站推广如何做广告联盟平台排名
  • 易语言可以做网站么软件推广赚钱
  • 化工网站制作网页设计需要学什么
  • 网站视频链接怎么做的建网站的公司
  • 广东外贸网站开发合肥网络推广服务
  • 网站做子域名凡科建站怎么收费
  • 在线做banner的网站各大搜索引擎提交入口
  • 销售平台系统白帽seo是什么
  • 辽宁网站开发南平网站seo
  • 在线生成手机网站原版百度
  • 做关于车的网站有哪些seo分析seo诊断
  • 个人网页代码html个人网页完整代码谷歌seo培训
  • 中国建设银行网站查询百度移动端关键词优化
  • 什么是自适应网站互联网广告行业
  • wordpress手机上传图片失败钦州seo
  • 建网站外包公司宁波seo超级外链工具
  • 东莞南城做网站推广的公司百度指数的数值代表什么
  • 没有页面的网站怎么做性能测试网推什么意思
  • 网站注册页面怎么做数据验证码迅雷bt磁力链 最好用的搜索引擎
  • 朝阳区网站开发公司深圳seo排名优化