必要条件和充分条件与分析问题的方法

news2025/1/22 9:23:16

作为一名软件工程师,大部分的工作时间都是在解决各种问题中度过的,相信大部分的工程师都有类似的感受。这些问题发生在不同的技术领域,不同的技术方向,不同的模块,甚至不同的环境下,不一而足,就像数学中的自然数可数无穷一样,我们可以一个个遍历它,但是无法穷尽所有的问题。这多少有点悲观,难道我们就没有办法了么? 不是这样的,问题有无数种,但是解决问题的通用思考方法却是有的,我们从一个数学概念讲起。

必要条件和充分条件

再进一步讨论之前,先来复习一下什么是必要条件和充分条件,这个概念应该是初中数学讲述的,并不陌生,但是真正能够掌握其确切定义的人却很少,如果用机械的方式加以定义,就是:

“当命题 ‘若p则q’ 为真,则p为充分条件,q为必要条件"

如果不结合具体的示例,可能很少有人会理解这句话,我们再分析的详细一点:

必要条件:对某事件的成立来说(至少)必要的条件。

充分条件:对某事件的成立来说(足够)充分的条件。

用这样得到方式解释好像还是不够清楚,举个例子:

居住在广东是居住在珠海的必要条件,居住在珠海市是居住在广东省的充分条件。

一个人如果居住在广东省,就有可能居住在珠海,而一个人如果居住在珠海,就一定居住在广东。根据这样的定义,如果我们把充分条件和必要条件联想成:

必要条件=宽松的条件

充分条件=严格的条件

或许会比较容易理解了。

类似的例子可以举很多,比如,考察一场考试年级第一和班级第一的关系。

如果同学A考了班级第一,那么他不一定是全级第一,但是如果这位同学考的是全年纪第一,那么它一定是班级第一,用图形表示就是:

绿色部分就是那些班级考试第一,但是并不是全年级第一的同学,班级第一每个班都有一个,但是全年级第一只有一个。

根据上面两个例子,我们可以把必要条件和充分条件分别视为:

必要条件=大范围,充分条件=小范围

将上述内容整理后,就会是:

必要条件=宽松的条件 = 大范围

充分条件= 严格的条件=小范围

当逐渐缩小必要条件的范围,缩小到和充分条件重合的时候,我们就认为,我们找到了充要条件。

如何解BUG

解BUG一般是根据现象找原因,我们要根据必要条件去寻找充分条件。

但是,通常一个问题可能会有多种现象,有些现象是观察到的,有些现象是待发现的。

这个时候,如果我们一味的从现象入手,拘泥于某个个别现象去寻找问题,很可能会陷入死胡同无法自拔,更何况现象空间是未知的,可能随时会有新的现象或者规律被发现,当这些现象和规律全部摆到你的面前的时候,处理的复杂性大大增加。

这个时候,我们总的方向是从各种现象入手,寻找这些现象背后的规律和联系,从中寻找最大公约,并且逐渐缩小这个公约范围直到它既能覆盖所有的现象,也能从逻辑上演绎出最后的问题。

所以,一开始从现象归纳到最大公约量的时候,我们用的是归纳的方式,这其中甚至会包含一些大胆的假设和猜测,但是我们基本定位到这个最大公约的范围之后,就可以大胆的使用演绎推理了,直到你发现,你演绎结果恰好是这个问题本身,这个时候,我们就找到了这个问题的rootcause.

如何打补丁

在芯片领域有一个流行的观点,如果硬件部署后出了BUG,那么问题也就成了feature.,一般需要用软件打补丁的方式去解决。一个好的补丁,一定是满足充分必要条件的补丁。


结束

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/151685.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

韩顺平老师的Linux基础学习笔记 (下)

Linux学习笔记 前言:本系列笔记的参考由 2021韩顺平 一周学会Linux 总结而成,希望能给学习Linux的同学一些帮助。也感谢韩老师录制的视频给我带来了非常巨大的收获! 目录: 韩顺平老师的Linux基础学习笔记 (上)韩顺平老师的Linu…

swagger2 介绍+注解说明

简介: 为什么要用swagger,我的理由是方便,作为后端开放人员,最烦的事就是自己写接口文档和前端交互是不是需要各种参数很繁琐,项目集成swagger后就能自动生成接口文档,做到前端、后端联调接口文档的及时性和便利性。 …

Eureka与Nacos的区别

Eureka 工作原理图 Nacos工作原理图 Eureka与Nacos相同点 都支持服务注册和服务拉取。 都支持服务提供者心跳方式做健康检测。 Eureka与Nacos区别 Nacos支持服务端主动检测提供者状态:临时实例采用心跳模式,非临时实例采用主动检测模式 临时实例心跳…

理解Java的线程安全问题

目录 目录 举例:三个窗口卖票 运行结果:出现重票 如何解决? 方式一:同步代码块,第一个例子 运行结果: 改进: 运行结果: 方法一:同步代码块的第二个例子。把锁和ti…

使用opencv进行脸部识别

1.读取人脸部图片 引入需要的库,并读取人脸的图片 import cv2 import matplotlib.pyplot as plt import numpy as np# 定义t2s函数,方便查看是否对图片进行RGB通道转换 def t2s(img):return cv2.cvtColor(img, cv2.COLOR_BGR2RGB)# 读取图片 img cv2.…

10个PMP冷知识,项目经理看完都说长见识

早上好,我是老原。每次聊起考证啊,我内心总是充满遗憾——毕竟现在的市场情况,让很多项目经理对考证都不看好。但是啊,这群吹证书无用论的小友,总让我想起前几年吹学习无用论的时候,多么的异曲同工&#xf…

PageHelper分页规则

1.问题 1.1.PageHelper先开启分页&#xff0c;后对list数据操作 Overridepublic PageInfo<HdQueryVo> getRecordsByView(int pageNo, int pageSize) {PageHelper.startPage(pageNo,pageSize);List<HdQueryVo> hdQueryVosByView actionMapper.getActionByView();…

TP6(thinkphp6)队列与延时队列

安装 在此我就不再略过TP6的项目创建过程了&#xff0c;大致就是安装composer工具&#xff0c;安装成功以后&#xff0c;再使用composer去创建项目即可。 think-queue 安装 composer require topthink/think-queue 项目中添加驱动配置 我们需要在安装好的config下找到 queu…

SAP工作流任务

前言 灵活工作流沿用的传统工作流的活动节点&#xff0c;只是不再体现在流程图上&#xff0c;工作流的活动根据是否需要代理人可以分为两类&#xff0c;一类是自动后台处理的步骤&#xff0c;另外一类是需要代理人处理的步骤&#xff08;一般为决策节点&#xff09;&#xff0c…

线程通信例子

目录 线程通信的例子&#xff1a;使用两个线程打印1-100。线程1&#xff0c;线程2&#xff0c;交替打印 涉及的3个方法&#xff1a; 运行结果&#xff1a; 把锁改为其他对象 运行结果报错&#xff1a; 改进&#xff0c;把notify和wait的调用者改为obj sleep()和wait()的…

【数据结构】—— Java实现单链表

Java实现单链表一、一链表的概念及结构二、头节点与头指针的异同三、代码实现一、一链表的概念及结构 链表是一种物理存储结构上非连续存储结构&#xff0c;数据元素的逻辑顺序是通过链表中的引用链接次序实现的 。 注意&#xff1a; 从上图可以看出&#xff0c;链式结构在逻…

MobPush for SDK API

推送监听接口 (addPushReceiver) 描述&#xff1a;添加推送监听&#xff0c;可监听接收到的自定义消息(透传消息)、通知消息、通知栏点击事件、别名和标签变更操作。 /*** com.mob.pushsdk.MobPush.class* MobPush推送监听接口* param receiver 监听*/ public static void ad…

Databend 开源周报 #74

Databend 是一款强大的云数仓。专为弹性和高效设计&#xff0c;自由且开源。 即刻体验云服务&#xff1a;https://app.databend.com。 What’s New 探索 Databend 本周新进展&#xff0c;遇到更贴近你心意的 Databend 。 Features & Improvements Meta watch client …

【Word2021交叉引用参考文献格式】

Word2021交叉引用参考文献格式1 格式分类2 格式设置方法2.1 引用单个参考文献2.2 引用连续两个参考文献2.3 引用连续三个及三个以上的参考文献1 格式分类 按照引用参考文献的数量&#xff0c;格式一般分为三种&#xff1a; 1、引用单个参考文献&#xff0c;样例&#xff1a;我…

Leetcode回溯法题解

第一题 17. 电话号码的字母组合 题目描述&#xff1a;给定一个仅包含数字 2-9 的字符串&#xff0c;返回所有它能表示的字母组合。答案可以按任意顺序返回。 给出数字到字母的映射如下&#xff08;与电话按键相同&#xff09;。注意 1 不对应任何字母。 示例1&#xff1a;…

Linux yum 使用手册,以及内网源搭建

Linux yum 内网源搭建 序 在 Linux 中&#xff0c;我们经常安装各个开源网站编写的代码、软件&#xff0c;在安装的时候各个软件之间有各种依赖关系&#xff0c;还可能出现版本问题&#xff0c;比如 Centos7 支持的软件&#xff0c; Centos6 就未必支持。如果是 Java 开发应该…

ArcGIS基础实验操作100例--实验73创建闭合线内部缓冲区

本实验专栏参考自汤国安教授《地理信息系统基础实验操作100例》一书 实验平台&#xff1a;ArcGIS 10.6 实验数据&#xff1a;请访问实验1&#xff08;传送门&#xff09; 高级编辑篇--实验73 创建闭合线内部缓冲区 目录 一、实验背景 二、实验数据 三、实验步骤 &#xff0…

K8S ReplicaSet 原理 示例 HPA扩容

K8S ReplicaSet 基本使用 K8S ReplicaSet 对象的作用是在任意时间点保持一组稳定的副本Pod运行&#xff0c;因此&#xff0c;它通常用于保证指定数量的相同Pod的可用性。乍一看&#xff0c; ReplicaSet 对象的定义跟 Replication Controller 并没有什么区别&#xff0c;都是维…

AI检测人员工衣工服着装不规范识别系统 yolo

AI检测人员工衣工服着装不规范识别系统基于opencvyolo网络深度学习模型对现场画面中人员着装穿戴实时监测分析。我们使用YOLO(你只看一次)算法进行对象检测。YOLO是一个聪明的卷积神经网络(CNN)&#xff0c;用于实时进行目标检测。该算法将单个神经网络应用于完整的图像&#x…

Vivado综合属性之SRL_STYLE

本文介绍综合属性SRL_STYLE取register、srl、srl_reg、reg_srl、reg_srl_reg和block中的值时&#xff0c;对Schematic的影响。 SRL_STYLE用于指导Vivado将SRL&#xff08;移位寄存器&#xff09;映射为何种形式。 目录 默认值 测试代码 原理图 SRL_STYLE配置为register …