✌粤嵌—2024/3/29—合并两个有序数组 + 赎金信✌

1. 合并两个有序数组

代码实现:

方法一:将数组num2中的元素添加到数组num1的末尾,再排序
void merge(int *nums1, int nums1Size, int m, int *nums2, int nums2Size, int n) {for (int i = 0; i < n; i++) {nums1[m++] = nums2[i];}// 冒泡排序int flag = 1;for (int i = m - 1; flag && i > 0; i--) {flag = 0;for (int j = 0; j < i; j++) {if (nums1[j] > nums1[j + 1]) {flag = 1;int temp = nums1[j];nums1[j] = nums1[j + 1];nums1[j + 1] = temp;}}}
}
方法二:将数组num2中的元素一个一个按顺序添加到数组num1中

void merge(int *nums1, int nums1Size, int m, int *nums2, int nums2Size, int n) {int i, j;for (i = 0; i < n; i++) {// 数组num1中没有元素,直接插入 || >= num1中所有元素,插入到末尾if (m == 0 || nums2[i] >= nums1[m - 1]) {nums1[m++] = nums2[i];} else {// 找到插入位置:jfor (j = m; j > 0; j--) {if (nums1[j - 1] > nums2[i]) {nums1[j] = nums1[j - 1];} else {break;}}nums1[j] = nums2[i];m++;}}
}

2. 赎金信

代码实现:

哈希表

bool canConstruct(char *ransomNote, char *magazine) {int hash[26] = {0};for (int i = 0; i < strlen(ransomNote); i++) {hash[ransomNote[i] - 'a']++;}for (int i = 0; i < strlen(magazine); i++) {if (hash[magazine[i] - 'a']) {hash[magazine[i] - 'a']--;}}for (int i = 0; i < 26; i++) {if (hash[i]) {return false;}}return true;
}

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Navicat 干货 | 了解 PostgreSQL 规则

PostgreSQL 是一个强大的开源关系型数据库管理系统&#xff0c;为增强数据管理和操作提供了丰富的功能。这些功能中包含了规则&#xff0c;这是一种用于控制数据库内部查询和命令处理方式的机制。本文将探讨 PostgreSQL 规则的工作原理&#xff0c;以及它们与触发器的区别&…

【IDEA--dubug相关】Debug项目时启动不了(启动至一半卡住)

下面是一些经常在日常debug时用到的场景&#xff0c;方便查看、与君共勉&#xff01; 文章目录 1. 问题背景2. 可能原因3. 解决办法 最近遇到的一种SpringBoot启动失败的情况&#xff0c;如果有相同情况的&#xff0c;可以看看是否是这个原因 1. 问题背景 用Debug模式启动bo…

鸿蒙入门04-真机运行“遥遥领先”

如果你有一台真的 "遥遥领先"那么是可以直接在手机上真机运行你的项目的我们也来尝试一下运行 一、手机设置开发者模式 打开手机设置 打开手机设置界面 向下滑动到关于手机位置 快速连续点击版本号位置 下图所示位置快速连续点击 打开 3 - 5 次即可 会提示您已经进…

React-Redux(一)

​&#x1f308;个人主页&#xff1a;前端青山 &#x1f525;系列专栏&#xff1a;React篇 &#x1f516;人终将被年少不可得之物困其一生 依旧青山,本期给大家带来React篇专栏内容:React-Redux&#xff08;一&#xff09; 目录 1、简介 2、三大原则&#xff08;重点&#xf…

数据结构——线性表(顺序表)

数据结构——线性表&#xff08;顺序表&#xff09; 什么是线性表顺序表顺序表结构定义初始化顺序表插入表尾插入扩容遍历指定位置插入头插 删除指定位置删除头删尾删 查找和修改 我们今天进入数据结构的学习&#xff0c;今天我们从梦开始的地方&#xff1a;顺序表。 什么是线…

支付宝支付之SpringBoot整合支付宝入门

支付宝支付 对接流程 申请阿里支付官方企业账号配置应用签约产品获取RSAKey&#xff08;非对称加密&#xff09;必须获得两个加密串&#xff1a;一个公钥&#xff0c;一个密钥SDK功能开发业务对接支付回调支付组件 核心所需的参数 APPID商家私钥支付宝公钥支付回调地址网关…

MDC使用手册精讲

MDC 背景&#xff1a; 线上排查问题时&#xff0c;请求在多个微服务之间进行调用&#xff0c;并发量较大的情况下&#xff0c;想跟踪某一个请求的链路&#xff0c;是需要花费一些时间才能梳理出来&#xff0c;而且还依赖于你的业务字段。而我们需要的是快速定位&#xff0c;快…

Qt 实战(2)搭建开发环境 | 2.1、Windows下安装QT

一、Windows下安装QT 1、QT官网 QT官网&#xff1a;https://download.qt.io/&#xff0c;打开官网地址&#xff0c;如下&#xff1a; 目录结构介绍 目录说明snapshots预览版&#xff0c;最新的开发测试中的 Qt 库和开发工具onlineQt 在线安装源official_releases正式发布版&am…

python将日志写入文件(超详细)

python将日志写入文件(超详细) 1、需求 我们在训练模型的时候&#xff0c;有时候需要将训练日志输出到一个文件中&#xff0c;方便随时查看训练日志。 训练模型时候&#xff0c;训练日志在控制台展示&#xff0c;关闭控制台后日志会消失。这时&#xff0c;我们需要将控制台中…

STM32之HAL开发——CubeMX配置串行Flash文件系统

配置流程 在开始配置FATFS前&#xff0c;需要提前配置好RCC的时钟&#xff0c;以及时钟的频率&#xff0c;另外还要配置好Debug选项&#xff08;选择串行&#xff09; 选项介绍 文件系统适用于SD卡&#xff0c;Disk磁盘等&#xff0c;需要我们将对应的驱动打开才可以使用。 …

STM32H7 QSPI的寄存器和功能介绍

目录 概述 1 认识QSPI 1.1 QSPI介绍 1.2 QUADSPI 主要特性 2 QUADSPI 功能说明 2.1 双闪存模式禁止 2.2 双闪存模式使能 3 QUADSPI 的用法 3.1 间接模式的操作步骤 3.1.1 QUADSPI 间接模式时配置帧模式 3.1.2 写控制寄存器 (QUADSPI_CR) 3.1.3 写通信配置寄存器 (…

西北新作 | 咸阳金域华庭售楼处落成

优积科技再拓新品,在历史悠久的陕西省咸阳市核心区域&#xff0c;成功打造了一座创新模块化设计的售楼处。 咸阳&#xff0c;这座镶嵌于八百里秦川温润腹地的城市&#xff0c;坐拥渭水潺潺南流&#xff0c;峻嶒嵯峨的嵕山巍然北峙&#xff0c;因其南北皆得山水之阳刚之美&…