【C++】 —— 笔试刷题day_22

news2025/4/21 6:21:30

一、添加字符

题目解析

在这里插入图片描述

这道题,给定两个字符串AB,字符串A的长度要小于B的长度;

现在我们要对A字符串添加字符,使得A字符串长度等于B字符串的长度,并且要求对应位置的字母尽量相等,然后求出来不相等的字符最少有多少位。

算法思路

对于这道题而言,我们可以在A字符串的开头和结尾位置添加字符(那我们添加的字符肯定是和B字符串对应位置的字符相等的),所以我们就只需要在B字符串中找到一段区间(这个区间的长度等于A的长度,然后让这个区间内的字符尽可能和A字符串对应字符相等)。

看到这里,可能会想到滑动窗口、双指针算法来找更加高效的方法;

但这道题,B字符串的长度小于等于50A字符串的长度小于等于B的长度,我们使用暴力解法即可。

暴力解法:

遍历B字符串,找以每一个位置为开始,长度等于A的长度的子串,然后找到不相等的字符最少的,记录一下结果即可。

代码实现

这里注意:假设A字符串的长度为nB字符串的长度为m

遍历B字符串时,我们要找i位置后面的n个字符,所以我们遍历到m-n位置即可

#include <iostream>
using namespace std;

int main() {
    string str1, str2;
    cin >> str1 >> str2;
    int n = str1.size();
    int m = str2.size();
    int ret = m;
    for (int i = 0; i < m - n + 1; i++) {//从0位置遍历到m-n位置
        int tmp = 0;//记录以i位置开始
        for (int j = 0; j < n; j++) {
            if (str1[j] != str2[i + j])
                tmp++;
        }
        ret = min(ret, tmp);
    }
    cout << ret << endl;
    return 0;
}

二、数组变换

题目解析

在这里插入图片描述

题目给定一个数组,现在呢,我们要将数组中的所有数相等;

我们可以进行的操作:将数组中的一个数改为这个数的两倍(说白了就是进行乘2操作

这个操作没有次数限制,可以使用也可以不使用,让我们判断给定的数组能否通过乘2操作将所有数变成一样的。

算法思路

这道题,首先的问题就是:我们如何去判断给定的数组是否能够将所有数变成一样的。

首先,肯定就是,暴力枚举,枚举出来所以的两个数的组合,然后依次判断这两个数能否通过操作变成一样的数。

这道题数据个数是小于50的,暴力枚举也可能可以通过;

但是我们进行一下优化:

  • 我们知道进行乘2操作时,这个数是一直在变大的,所以如果整个数组中的所有数是可以变成一样的,那是不是可以理解为我们可以将所有数通过乘2操作,变成最大的那一个数。(如果无法变成最大的那一个数,那无论多少次操作都是不能变成同一个数的)。
  • 那我们就可以记录一下整个数组中最大的数num,然后遍历数组,判断每一个数能否通过乘2操作变成最大的数即可

那现在我们的问题就来到了如何去判断一个数,能否通过乘2操作变成另外一个数。

我们仔细想一下,如果x可以通过乘2操作变成y,那是不是说yx2^n倍?

我们乘2操作2,4,8,16,32......,这些都是2^n,这里如果x等于y,那y就是x1(2^0)。

那也就是y/x是一个2^n

那我们的问题就变成了判断一个数的2^n

这里暴力就是通过/2操作判断y/x每次/2的商是否是2的倍数。

这里介绍两种判断一个数是否是2^n次方的 方法:

  • x - (x & -x):如果x - (x & -x) == 0,那x就是2^n;否则就不是。
  • x & (x - 1):如果x & (x - 1) == 0,那x就是2^n;否则就不是。

在这里插入图片描述

代码实现

#include <iostream>
using namespace std;
const int N = 51;
int n;
int arr[N];
int num = 0;
bool fun()
{
    //判断是否能转换
    for(int i = 0;i<n;i++)
    {
        if(num % arr[i] != 0)
            return false;
        int b = num/arr[i];
        //判断b是否是2的n次方
        //if(b - (b&-b)!=0)  return false;
        if(b & (b-1) !=0)   return false;
    }
    return true;
}
int main() {
    cin>>n;
    for(int i = 0;i<n;i++)
    {
        cin>>arr[i];
        num = max(num,arr[i]);
    }
    if(fun()) cout<<"YES"<<endl;
    else cout<<"NO"<<endl;
    return 0;
}

三、装箱问题

题目解析

在这里插入图片描述

这道题,给一个箱子的容量v,和n个物品,和每一个物品的体积;

现在我们要在这n个物品中选择体积不超过v的物品,然后要求箱子的剩余空间最小。

算法思路

有系统学习过动态规划,或者了解过01背包问题,相比已经想到这道题思路了;

这道题就是01背包的一个应用。

题目要求我们箱子的剩余容量最小,我们反过来理解,就是我们在n个物品中选择体积不超过v的物品,然后要选择物品的总体积最大。

那这道题就简单了。思路就是动态规划-01背包

状态表示: dp[i][j]表示从n个物品中选择体积不超过j是物品,所选择物品总体积的最大值。

状态转移方程:

  • 对于i位置的物品,我们可以选择它,也可以不选择它;
  • 如果选择i位置的物品,dp[i][j] = dp[i-1][j-arr[i]] + arr[i]。(选择i物品,那就要从剩下的i-1位置中选择体积不超过j - arr[i]的物品;这里还要注意能不能选择i位置的问题)
  • 如果不选择i位置的物品,dp[i][j] = dp[i-1][j]。(不选择i位置的物品,那就要从剩下的i-1位置中选择体积不超过j的物品)。

这里如果i位置物品的体积大于j,那一定是不能选择i位置的。

在这里插入图片描述

代码实现

#include <iostream>
using namespace std;
const int N = 35;
const int M = 2e4+10;
int arr[N];
int dp[N][M];
int n,v;
int main()
{
    cin>>v>>n;
    for(int i = 1;i<=n;i++)
    {
        cin>>arr[i];
    }
    for(int i = 1;i<=n;i++)
    {
        for(int j = 1;j<=v;j++)
        {
            dp[i][j] = dp[i-1][j];
            if(j>=arr[i])
                dp[i][j] = max(dp[i][j], dp[i-1][j-arr[i]] + arr[i]);
        }
    }
    cout<<(v - dp[n][v])<<endl;
    return 0;
}

到这里本篇文章内容就结束了
感谢各位的支持

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

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

相关文章

【Android面试八股文】Android应用进程的启动流程【二】

应用进程 1.1 Android系统进程的启动过程&#xff1a; 1、init进程fork出Zygote进程后&#xff0c;Zygote进程会创建一个服务端socket&#xff0c;等待AMS发起socket请求。 同时&#xff0c;由Zygote进程fork出的SystemServer进程会启动各项系统服务&#xff0c;其中就包含了A…

“星睿O6” AI PC开发套件评测 - 部署PVE搭建All in One NAS服务器

Radxa O6平台上部署PVE搭建All in One NAS服务器 Radxa O6是一款性能卓越的单板计算机&#xff0c;其强劲的硬件配置和多样化的接口设计&#xff0c;使其成为家庭和小型企业理想的All in One服务器解决方案。值得一提的是&#xff0c;O6原生配备了两个5G网口&#xff0c;便于直…

全志H5,NanopiKP1lus移植QT5.12记录

移植步骤 机器环境下载QT5.12.0源码安装交叉编译器修改qmake.conf文件配置编译选项qt5的configure选项说明基本配置选项编译器和链接器选项功能模块配置第三方库集成注意事项 配置过程报错解决配置完成编译过程报错解决编译完成将arm-qt文件夹传送到开发板配置板子环境变量运行…

使用EXCEL绘制平滑曲线

播主播主&#xff0c;你都多少天没更新了&#xff01;&#xff01;&#xff01;泥在干什么&#xff1f;你还做这个账号麻&#xff1f;&#xff01;&#xff01;&#xff01; 做的做的&#xff08;哭唧唧&#xff09;&#xff0c;就是最近有些忙&#xff0c;以及…… 前言&…

Warcraft Logs [Classic] [WCL] Usage Wizard <HTOC>

‌HTOC&#xff08;十字军的试炼&#xff09;副本中各个BOSS的ID如下‌&#xff1a; ‌629 - 诺森德野兽‌ ‌633 - 加拉克苏斯大王‌ ‌637 - 派系冠军‌ ‌641 - 瓦格里双子‌ ‌645 - 阿努巴拉克‌ encounterID!637 and encounterID!641 encounterID NOT IN (637,641) 伤害 …

在服务器上部署MinIO Server

MinIO的优势 高性能&#xff1a;MinIO号称是目前速度最快的对象存储服务器&#xff0c;据称在标准硬件上&#xff0c;对象存储的读/写速度最高可以高达183 GB/s和171 GB/s&#xff0c;可惜我的磁盘跟不上 兼容性&#xff1a;MinIO基于Amazon S3协议&#xff0c;并提供了与S3兼…

一个改善Entity Framework异常处理和错误信息的开源项目

使用DDD从零构建一个完整的系统 使用Entity Framework作为ORM框架应该是绝大多数项目的选择&#xff0c;使得我们操作数据库变得简单方便&#xff1b;但是我们操作数据库&#xff0c;绝对是无法避免数据库发生异常的情况&#xff0c;数据库针对每一种异常也都会提供一个编码来…

计算机视觉——基于 Yolov8 目标检测与 OpenCV 光流实现目标追踪

1. 概述 目标检测&#xff08;Object Detection&#xff09;和目标追踪&#xff08;Object Tracking&#xff09;是计算机视觉中的两个关键技术&#xff0c;它们在多种实际应用场景中发挥着重要作用。 目标检测指的是在静态图像或视频帧中识别出特定类别的目标对象&#xff0…

PHP使用pandoc把markdown文件转为word

文章目录 首先安装pandocPHP处理 服务器操作系统是Linux&#xff0c;centos 首先安装pandoc yum install -y pandoc安装完成后输入如下代码&#xff0c;检查安装是否成功 pandoc --versionPHP处理 我把markdown内容存到了数据库里&#xff0c;所以要从数据库读取内容。对内容…

OBS 日期时间.毫秒时间脚本 date-and-time.lua

文章目录 OBS 日期时间.毫秒时间脚本&#xff1a;效果 OBS 日期时间.毫秒时间脚本&#xff1a; obs obslua source_name ""last_text "" format_string "" activated false-- 此函数用于获取精确的毫秒级时间戳&#…

探索大语言模型(LLM):目标、原理、挑战与解决方案

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言语言模型的目标语言模型的数学表示语言模型面临的挑战解决参数量巨大的方法1. 马尔可夫假设2. 神经网络语言模型3.自监督学习4. 分布式表示 脑图总结 前言 在自…

ES基本操作(Java API)

1. 导入restClient依赖 <!-- es --><dependency><groupId>org.elasticsearch.client</groupId><artifactId>elasticsearch-rest-high-level-client</artifactId><version>7.12.1</version></dependency> <!…

得物官网sign签名逆向分析

打开得物官网&#xff0c;点击鞋类&#xff0c;可以看到请求 直接搜sign function p(e) {return f()("".concat(e ? s()(e).sort().reduce(function(t, n) {return "".concat(t).concat(n).concat(e[n])}, "") : "", "048a9…

vivado 时钟IP核(MMCM PLL)

CMT简介 FPGA中时钟管理模块&#xff08;CMT&#xff09;包括PLL和MMCM&#xff0c;用于将时钟倍频(比如输入时钟25M&#xff0c;我们要产生50M时钟)、分频(在不影响系统功能的前提下&#xff0c;较低的工作时钟&#xff0c;能够降低系统功耗)、改变相位偏移或占空比等。 当需要…

hackmyvm-airbind

收集信息 arp-scan -l nmap -sS -v 192.168.195.162 访问扫描到的ip&#xff0c;直接跳转到登录页面&#xff0c;利用admin/admin弱口令登录 在settings.php中找到一处文件上传&#xff0c;上传一句话木马&#xff0c;上传成功 反弹shell 上传php-reverse-shell.php 抓包&am…

知识了解03——怎么解决使用npm包下载慢的问题?

1、为什么使用npm下载包会下载的慢 因为使用npm下载包时&#xff0c;默认使用国外服务器进行下载&#xff0c;此时的网络传输需要经过漫长的海底电缆&#xff0c;因此下载速度会变慢 2、怎么解决&#xff1f;&#xff08;切换镜像源&#xff09; &#xff08;1&#xff09;方…

【算法数据结构】leetcode37 解数独

37. 解数独 - 力扣&#xff08;LeetCode&#xff09; 题目描述&#xff1a; 题目要求每一行 &#xff0c;每一列&#xff0c;每个3*3 的子框只能出现一次。每个格子的数字范围1-9. 需要遍历每个空格填入可能的数字&#xff0c;并验证符合规则。如果符合就填入&#xff0c;不符…

招商信诺原点安全:一体化数据安全管理解决方案荣获“鑫智奖”!

近日&#xff0c;“鑫智奖 2025第七届金融数据智能优秀解决方案评选”榜单发布&#xff0c;原点安全申报的《招商信诺&#xff1a;数据安全一体化管理解决方案》荣获「信息安全创新优秀解决方案」。 “鑫智奖第七届金融数据智能优秀解决方案评选”活动由金科创新社主办&#x…

楼宇自控系统如何为现代建筑打造安全、舒适、节能方案

在科技飞速发展的当下&#xff0c;现代建筑对功能和品质的要求日益提升。楼宇自控系统作为建筑智能化的核心技术&#xff0c;宛如一位智慧的“管家”&#xff0c;凭借先进的技术手段&#xff0c;为现代建筑精心打造安全、舒适、节能的全方位解决方案&#xff0c;让建筑真正成为…

吃透LangChain(四):消息管理与聊天历史存储

消息存储在内存 下面我们展示一个简单的示例&#xff0c;其中聊天历史保存在内存中&#xff0c;此处通过全局 Python 字典实现。我们构建一个名为 get_session_history 的可调用对象&#xff0c;引用此字典以返回chatMessageHistory实例。通过在运行时向 RunnablewithMessageHi…