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

【蓝桥杯速成】| 2.逆向思维

题目一:青蛙跳台阶

题目描述

一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶。
求该青蛙跳上一个 n 级的台阶总共有多少种跳法。

解题步骤

选用递归的方法解决该问题!

使用递归只需要考虑清楚边界条件/终止条件,再写清楚单层循环逻辑

剩下的交给程序就好啦!

那么如果顺着一级一级去想会非常麻烦,

不妨倒着想想,青蛙以什么姿势跳上第n级台阶

是优雅的迈了一步?还是急速蹦了两级?

以jump(n)为求步数的函数,

根据该思路则有:jump(n)=jump(n-1)+jump(n-2)

此外jump(0)=1,jump(1)=1

这是按照规律得到的边界条件

整合到一起就是

int jump(int n){if(n==0 || n==1){return 1;}return jump(n-1)+jump(n-2);
}

那么主函数里只需要加一些输入输出,再用上我们的jump就好啦

int main(){int n;cin>>n;cout<<jump(n);return 0;	
}

code

#include<bits/stdc++.h>
using namespace std;int jump(int n){if(n==0 || n==1){return 1;}return jump(n-1)+jump(n-2);
}
int main(){int n;cin>>n;cout<<jump(n);return 0;	
}

 


 

题目二:丢失的数字

题目描述

268. 丢失的数字 - 力扣(LeetCode)

给定一个包含 [0, n] 中 n 个数的数组 nums ,找出 [0, n] 这个范围内没有出现在数组中的那个数。

解题步骤

1.小笨方法

利用排序和数组下标

排序后数组按照大小顺序排列,数组内元素值与数组下标一致

遍历数组依次比对检查

不符合就返回

还有一种情况是缺少最后一个,故在循环外return该值,即nums.size()

class Solution {
public:int missingNumber(vector<int>& nums) {sort(nums.begin(),nums.end());//对整个数组做排序for(int i=0;i<nums.size();i++){//利用下标检查if(nums[i] !=i)//不符合则返回该下标return i;}return nums.size();//都符合那就是少了最后一个!}
};

2.逆向思维+数学方法

反过来想如果没少,那么这个无序数组有什么特点?

虽然没有顺序但它完全就是一个等差数组,等差数组可以使用求和公式得到所有值的和

那么与当前数组的和取差值,就是丢失的数字

需要注意的是该数组首项为0,尾项为n,一共n+1个!!!

int n=nums.size();//获取数组大小
int sum=n*(n+1)/2;//没少的数组之和,首项为0,尾项为n,一共n+1个!
int s=0;//当前数组之和
for(int i=0;i<n;i++){s=s+nums[i];//累加统计
}
return sum-s;//相减得出丢失值

 也可以用accumulate函数替代遍历累加求和的代码

int s=accumulate(nums.begin(),nums.end(),0);
参数说明:
  • vec.begin():起始迭代器。

  • vec.end():结束迭代器。

  • 0:初始值(求和的起点)
     


 

 题目三:只出现一次的数字

题目描述

136. 只出现一次的数字 - 力扣(LeetCode)

给你一个 非空 整数数组 nums ,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。

你必须设计并实现线性时间复杂度的算法来解决此问题,且该算法只使用常量额外空间。

解题步骤

如果正向去做这题,那么就是进行遍历,统计每一个元素出现次数,对出现次数为1的元素进行返回,但这样占用空间,不符合线性时间复杂度

那么如何逆向想一想呢?从找一次到出现一次的元素,变为任务是消去出现两次的元素

每个元素均出现两次可以进行什么操作配对消除呢?

采用位运算中的异或运算,两者相同为0,不同为1

对nums数组中的所有元素逐个进行异或,最终结果就是只出现一次的元素

code

class Solution {
public:int singleNumber(vector<int>& nums) {int temp=nums[0];for(int i=1;i<nums.size();i++){temp^=nums[i];}return temp;}
};

相关文章:

【蓝桥杯速成】| 2.逆向思维

题目一&#xff1a;青蛙跳台阶 题目描述 一只青蛙一次可以跳上1级台阶&#xff0c;也可以跳上2级台阶。 求该青蛙跳上一个 n 级的台阶总共有多少种跳法。 解题步骤 选用递归的方法解决该问题&#xff01; 使用递归只需要考虑清楚边界条件/终止条件&#xff0c;再写清楚单层…...

halcon机器人视觉(四)calibrate_hand_eye_stationary_3d_sensor

目录 一、准备数据和模型二、按照表面匹配的的结果进行手眼标定三、根据标定结果计算CalObjInCamPose一、准备数据和模型 1、读3D模型:read_object_model_3d 2、创建表面匹配模板:create_surface_model 3、创建一个HALCON校准数据模型:create_calib_data read_object_mode…...

python-leetcode-叶子相似的树

872. 叶子相似的树 - 力扣&#xff08;LeetCode&#xff09; 下面是一个完整的 Python 函数&#xff0c;接收两个二叉树的根节点 root1 和 root2&#xff0c;返回它们是否叶相似。 代码实现 class TreeNode:def __init__(self, val0, leftNone, rightNone):self.val valself…...

<03.13>八股文补充知识

import java.lang.reflect.*; public class Main {public static void main(String[] args) throws Exception {// 获取 Class 对象//1. 通过类字面量Class<?> clazz Person.class;//2 通过对象实例化String str "Hello";Class<?> clazz_str str.ge…...

GraphRAG 融合 RAG:双剑合璧,精度更上一层楼

检索增强生成 (Retrieval-Augmented Generation, RAG) 已成为构建知识密集型 NLP 应用的标准范式。RAG 通过结合大型语言模型 (LLM) 的生成能力和外部知识库的检索能力,显著提升了生成结果的质量。然而,在某些场景下,仅依靠传统的 RAG 或 GraphRAG 可能无法达到最佳效果。本…...

ffmpeg + opencv 打静态库编译到可执行文件中

下载ffmpeg ,我下载的为6.0 版本,解压后执行: ./configure --enable-static --disable-shared --pkg-config-flags=“–static” --extra-cflags=“-fPIC” --extra-cxxflags=“-fPIC” --prefix=/usr/local2.等待配置完成,执行 make && make install 进行编译安装…...

2025探索短剧行业新可能报告40+份汇总解读|附PDF下载

原文链接&#xff1a;https://tecdat.cn/?p41043 近年来&#xff0c;短剧以其紧凑的剧情、碎片化的观看体验&#xff0c;迅速吸引了大量用户。百度作为互联网巨头&#xff0c;在短剧领域积极布局。从早期建立行业专属模型冷启动&#xff0c;到如今构建完整的商业生态&#xf…...

前端面试:如何实现预览 PDF 文件?

在前端开发中&#xff0c;实现 PDF 文件的预览是一个常见需求&#xff0c;尤其是在应用程序中需要用户查看文档时。以下是几种常见的方法&#xff0c;可以用来实现在网页中预览 PDF 文件&#xff1a; 方法一&#xff1a;使用 <iframe> 标签 1. 基本实现 最简单的方式是…...

STM32 内置的通讯协议

数据是以帧为单位发的 USART和UART的区别就是有没有同步功能 同步是两端设备有时钟连接&#xff0c;异步是没时钟连接&#xff0c;靠约定号的频率&#xff08;波特率&#xff09;接收发送数据 RTS和CTS是用来给外界发送已“可接收”或“可发送”信号的&#xff0c;一般用不到…...

一个简单的PHP框架

原文地址&#xff1a;一个简单的PHP框架 更多内容请关注&#xff1a;智想天开 框架概述 一个基本的 PHP 框架通常包含以下几个部分&#xff1a; 前端控制器&#xff08;Front Controller&#xff09;&#xff1a;处理所有的 HTTP 请求&#xff0c;统一入口。 路由器&#xf…...

什么是SpringCloud?为何要选择SpringCloud?

什么是 Spring Cloud&#xff1f; Spring Cloud 是一套基于 Spring Boot 构建的 微服务架构解决方案&#xff0c;提供了一整套微服务开发所需的组件&#xff0c;如服务注册与发现、配置管理、负载均衡、熔断机制、网关等。它基于 Spring 生态系统&#xff0c;简化了分布式系统…...

信息安全访问控制、抗攻击技术、安全体系和评估(高软42)

系列文章目录 信息安全访问控制、抗攻击技术、安全体系和评估 文章目录 系列文章目录前言一、信息安全技术1.访问控制2.抗攻击技术 二、欺骗技术1.ARP欺骗2.DNS欺骗3.IP欺骗 三、抗攻击技术1.端口扫描2.强化TCP/IP堆栈 四、保证体系和评估1.保证体系2.安全风险管理 五、真题在…...

晋升系列4:学习方法

每一个成功的人&#xff0c;都是从底层开始打怪&#xff0c;不断的总结经验&#xff0c;一步一步打上来的。在这个过程中需要坚持、总结方法论。 对一件事情长久坚持的人其实比较少&#xff0c;在坚持的人中&#xff0c;不断的总结优化的更少&#xff0c;所以最终达到高级别的…...

脑电波控制设备:基于典型相关分析(CCA)的脑机接口频率精准解码方法

文章目录 前言一、CCA的用途二、频率求解思路三、输入数据结构四、判断方法五、matlab实践1.数据集获取及处理2.matlab代码3.运行及结果 六、参考文献 前言 在脑机接口(BCI)领域&#xff0c;有SSVEP方向&#xff0c;中文叫做稳态视觉诱发电位&#xff0c;当人观看闪烁的视觉刺激…...

Android Spinner总结

文章目录 Android Spinner总结概述简单使用自定义布局自定义Adapter添加分割线源码下载 Android Spinner总结 概述 在 Android 中&#xff0c;Spinner 是一个下拉选择框。 简单使用 xml布局&#xff1a; <Spinnerandroid:id"id/spinner1"android:layout_width&…...

element-ui layout 组件源码分享

layout 布局组件源码分享&#xff0c;主要从以下两个方面&#xff1a; 1、row 组件属性。 2、col 组件属性。 一、row 组件属性。 1.1 gutter 栅栏间隔&#xff0c;类型为 number&#xff0c;默认 0。 1.2 type 布局模式&#xff0c;可选 flex&#xff0c;现代浏览器下有效…...

OBJ文件生成PCD文件(python 实现)

代码实现 将 .obj 文件转换为 .pcd&#xff08;点云数据&#xff09; 代码文件。 import open3d as o3d# 加载 .obj 文件 mesh o3d.io.read_triangle_mesh("bunny.obj")# 检查是否成功加载 if not mesh.has_vertices():print("无法加载 .obj 文件&#xff0c…...

LinPEAS 使用最佳实践指南

在渗透测试和权限提升评估中&#xff0c;LinPEAS&#xff08;Linux Privilege Escalation Awesome Script&#xff09;是⼀个⽤来搜索类unix主机上可能的提权路径的⾃动化脚本。本文将介绍使用 LinPEAS 的最佳实践方案&#xff0c;并针对不同环境&#xff08;如无 curl 的情况&…...

c++介绍智能指针 十二(1)

普通指针&#xff1a;指向内存区域的地址变量。使用普通指针容易出现一些程序错误。 如果一个指针所指向的内存区域是动态分配的&#xff0c;那么这个指针变量离开了所在的作用域&#xff0c;这块内存也不会自动销毁。动态内存不进行释放就会导致内存泄露。如果一个指针指向已…...

Vue的scoped原理是什么?

scoped的工作原理 当在 <style> 标签上使用 scoped 属性时&#xff0c;Vue 会为当前组件的每个元素添加一个唯一的 data-v-xxxxxx 属性&#xff0c;并将样式规则中的选择器修改为包含该属性的形式。 编译阶段&#xff1a; 在编译 .vue 文件时&#xff0c;Vue 的编译器…...

大白话解释 React 中高阶组件(HOC)的概念和应用场景,并实现一个简单的 HOC。

高阶组件&#xff08;HOC&#xff09;的概念 在 React 里&#xff0c;高阶组件&#xff08;Higher-Order Component&#xff0c;简称 HOC&#xff09;就像是一个“超级工厂函数”。它本身是一个函数&#xff0c;而且这个函数接收一个组件作为参数&#xff0c;然后返回一个新的…...

深入浅出C++ STL:统领STL全局

深入浅出C STL&#xff1a;统领STL全局 深入浅出C STL&#xff1a;统领STL全局github主页地址前言一、STL的前世今生1.1 什么是STL&#xff1f;1.2 STL版本演进 二、STL六大核心组件详解2.1 容器&#xff08;Containers&#xff09;容器性能对照表 2.2 算法&#xff08;Algorit…...

k8s面试题总结(十五)

1.如何使用Kubernetes进行多环境部署&#xff08;如开发&#xff0c;测试和生产环境&#xff09;&#xff1f; 使用命名空间&#xff08;namespaces&#xff09;&#xff1a; 命名空间是用于逻辑隔离和资源分组的一种方式&#xff0c;可以为每个环境创建单独的命名空间。 2.使…...

Appium等待机制--强制等待、隐式等待、显式等待

书接上回&#xff0c;Appium高级操作--其他操作-CSDN博客文章浏览阅读182次&#xff0c;点赞6次&#xff0c;收藏7次。书接上回Appium高级操作--从源码角度解析--模拟复杂手势操作-CSDN博客。https://blog.csdn.net/fantasy_4/article/details/146162851主要讲解了Appium的一些…...

Vue源码深度解析:从2.x到3.x的架构演进与核心原理剖析

Vue源码深度解析&#xff1a;从2.x到3.x的架构演进与核心原理剖析 一、框架演变&#xff1a;从Vue2到Vue3的跨越 1.1 革命性升级 Vue3的发布标志着前端框架进入新纪元&#xff0c;其核心改进体现在三个方面&#xff1a; 性能飞跃&#xff1a;包体积减少41%&#xff0c;初始…...

计算机视觉cv2入门之图像的读取,显示,与保存

在计算机视觉领域&#xff0c;Python的cv2库是一个不可或缺的工具&#xff0c;它提供了丰富的图像处理功能。作为OpenCV的Python接口&#xff0c;cv2使得图像处理的实现变得简单而高效。 示例图片 目录 opencv获取方式 图像基本知识 颜色空间 RGB HSV 图像格式 BMP格式 …...

前置机跟服务器的关系

在复杂的IT系统架构中&#xff0c;前置机与服务器的协同配合是保障业务高效、安全运行的关键。两者的关系既非简单的上下级&#xff0c;也非独立个体&#xff0c;而是通过功能分层与职责分工&#xff0c;构建起一套既能应对高并发压力、又能抵御安全风险的弹性体系。 在当今复…...

【Vue】el-dialog的2种封装方法(父子组件双向通信),$emit触发父事件/.sync修饰符双向绑定

🤵 作者:coderYYY 🧑 个人简介:前端程序媛,目前主攻web前端,后端辅助,其他技术知识也会偶尔分享🍀欢迎和我一起交流!🚀(评论和私信一般会回!!) 👉 个人专栏推荐:《前端项目教程以及代码》 前言 在现代Vue.js开发中,el-dialog组件作为ElementUI库中的一个…...

CCF CSP 第30次(2023.09)(1_坐标变换_C++)(先输入再计算;边输入边计算)

CCF CSP 第30次&#xff08;2023.09&#xff09;&#xff08;1_坐标变换_C&#xff09; 题目描述&#xff1a;输入格式&#xff1a;输出格式&#xff1a;样例输入&#xff1a;样例输出&#xff1a;样例解释&#xff1a;子任务&#xff1a;解题思路&#xff1a;思路一&#xff0…...

【QT】事件系统入门——QEvent 基础与示例

一、事件介绍 事件是 应用程序内部或者外部产生的事情或者动作的统称 在 Qt 中使用一个对象来表示一个事件。所有的 Qt 事件均继承于抽象类 QEvent。事件是由系统或者 Qt 平台本身在不同的时刻发出的。当用户按下鼠标、敲下键盘&#xff0c;或者是窗口需要重新绘制的时候&…...