C++/JavaScript ⭐算法OJ⭐下一个排列
题目描述 31. Next Permutation
A permutation of an array of integers is an arrangement of its members into a sequence or linear order.
For example, for arr = [1,2,3], the following are all the permutations of arr: [1, 2, 3], [1, 3, 2], [2, 1, 3], [2, 3, 1], [3, 1, 2], [3, 2, 1].
The next permutation of an array of integers is the next lexicographically greater permutation of its integer. More formally, if all the permutations of the array are sorted in one container according to their lexicographical order, then the next permutation of that array is the permutation that follows it in the sorted container. If such arrangement is not possible, the array must be rearranged as the lowest possible order (i.e., sorted in ascending order).
For example, the next permutation of arr = [1,2,3] is [1,3,2].
Similarly, the next permutation of arr = [2,3,1] is [3,1,2].
While the next permutation of arr = [3,2,1] is [1,2,3] because [3,2,1] does not have a lexicographical larger rearrangement.
Given an array of integers nums, find the next permutation of nums.
The replacement must be in place and use only constant extra memory.
给定一个整数数组,找到它的下一个排列。下一个排列是指将数组中的元素重新排列成字典序中下一个更大的排列。如果不存在下一个更大的排列,则将数组重新排列为字典序最小的排列(即升序排列)。
解题思路
- 从数组的末尾开始,找到第一个不满足递增关系的元素
nums[i],即nums[i]<nums[i+1]。 - 如果找不到这样的
i,说明数组已经是最大的排列,直接反转数组即可。 - 如果找到了
i,再从数组的末尾开始,找到第一个大于nums[i]的元素nums[j]。 - 交换
nums[i]和nums[j]。 - 最后将
i之后的元素反转,得到下一个排列。
步骤详解
- 步骤 1:从后向前找到第一个不满足递增关系的元素
nums[i]。 - 步骤 2:从后向前找到第一个大于
nums[i]的元素nums[j]。 - 步骤 3:交换
nums[i]和nums[j]。 - 步骤 4:将
i之后的元素反转。
class Solution {
public:void nextPermutation(vector<int>& nums) {int n = nums.size();int i = n - 2;// 步骤 1:找到第一个不满足递增关系的元素while (i >= 0 && nums[i] >= nums[i + 1]) {i--;}if (i >= 0) {int j = n - 1;// 步骤 2:找到第一个大于 nums[i] 的元素while (j >= 0 && nums[j] <= nums[i]) {j--;}// 步骤 3:交换 nums[i] 和 nums[j]swap(nums[i], nums[j]);}// 步骤 4:反转 i 之后的元素reverse(nums.begin() + i + 1, nums.end());}
};
/*** @param {number[]} nums* @return {void} Do not return anything, modify nums in-place instead.*/
var nextPermutation = function(nums) {let n = nums.length;let i = n - 2;// 步骤 1:找到第一个不满足递增关系的元素while (i >= 0 && nums[i] >= nums[i + 1]) {i--;}if (i >= 0) {let j = n - 1;// 步骤 2:找到第一个大于 nums[i] 的元素while (j >= 0 && nums[j] <= nums[i]) {j--;}// 步骤 3:交换 nums[i] 和 nums[j][nums[i], nums[j]] = [nums[j], nums[i]];}// 步骤 4:反转 i 之后的元素let left = i + 1, right = n - 1;while (left < right) {[nums[left], nums[right]] = [nums[right], nums[left]];left++;right--;}
};
相关文章:
C++/JavaScript ⭐算法OJ⭐下一个排列
题目描述 31. Next Permutation A permutation of an array of integers is an arrangement of its members into a sequence or linear order. For example, for arr [1,2,3], the following are all the permutations of arr: [1, 2, 3], [1, 3, 2], [2, 1, 3], [2, 3, 1]…...
《Mycat核心技术》第17章:实现MySQL的读写分离
作者:冰河 星球:http://m6z.cn/6aeFbs 博客:https://binghe.gitcode.host 文章汇总:https://binghe.gitcode.host/md/all/all.html 星球项目地址:https://binghe.gitcode.host/md/zsxq/introduce.html 沉淀,…...
Windows 11 使用容器(Docker Podman)
文章目录 背景1、相关网站1.1、WSL1.2、Docker1.3、Podman 2、环境3、安装部署3.1、安装 WSL3.2、Docker3.2.1、Docker Desktop3.2.1.1、安装3.2.1.2、拉取镜像3.2.1.3、启动容器 3.3、Podman3.3.1、安装3.3.2、使用3.3.3、异常处理 总结 背景 Windows 系统中使用容器…...
代码审计入门学习之sql注入
路由规则 入口文件:index.php <?php // ---------------------------------------------------------------------- // | wuzhicms [ 五指互联网站内容管理系统 ] // | Copyright (c) 2014-2015 http://www.wuzhicms.com All rights reserved. // | Licensed …...
2024信息技术、信息安全、网络安全、数据安全等国家标准合集共125份。
2024信息技术、信息安全、网络安全、数据安全等国家标准合集,共125份。 一、2024信息技术标准(54份) GB_T 17966-2024 信息技术 微处理器系统 浮点运算.pdf GB_T 17969.8-2024 信息技术 对象标识符登记机构操作规程 第8部分:通用…...
element ui的select选择框
我们首先先试一下,这个东西怎么玩的 <el-select v-model"select" change"changeSelect"><el-option value"香蕉"></el-option><el-option value"菠萝"></el-option><el-option value&quo…...
文档检索服务平台
文档检索服务平台是基于Elasticsearch的全文检索,包含数据采集、数据清洗、数据转换、数据检索等模块。 项目地址:Github、国内Gitee 演示地址:http://silianpan.cn/gdss/ 以下是演示角色和账号(密码同账号)…...
使用FastAPI进行可视化部署
文章目录 一、FastAPI介绍二、环境配置三、示例代码1.app.py代码如下2.websocket_handler.py 代码如下3.运行app4.遇到的问题与解决 一、FastAPI介绍 FastAPI是一个高性能的Python Web框架,它基于Starlette并利用了 Python类型提示的优势。它可以帮助我们快速构建具…...
设计模式 之 工厂模式(简单工厂模式、工厂方法模式、抽象工厂模式)(C++)
文章目录 C 工厂模式引言一、简单工厂模式概念实现步骤示例代码优缺点 二、工厂方法模式概念实现步骤示例代码优缺点 三、抽象工厂模式概念实现步骤示例代码优缺点 C 工厂模式 引言 在 C 编程中,对象的创建是一个常见且基础的操作。然而,当项目规模逐渐…...
3、Kubernetes 集群部署 Prometheus 和 Grafana
Kubernetes 集群部署 Prometheus 和 Grafana node-exporter 安装Prometheus 安装和配置Prometheus 配置热加载Grafana 安装部署Grafana 配置 实验环境 控制节点/master01 192.168.110.10 工作节点/node01 192.168.110.20 工作节点/node02 192.168.110.30 node-exporter 安装 #…...
【C语言】第八期——指针
目录 1 初始指针 2 获取变量的地址 3 定义指针变量、取地址、取值 3.1 定义指针变量 3.2 取地址、取值 4 对指针变量进行读写操作 5 指针变量作为函数参数 6 数组与指针 6.1 指针元素指向数组 6.2 指针加减运算(了解) 6.2.1 指针加减具体数字…...
如何在 Mac 上安装并配置 JDK 环境变量
如何在Mac上安装并配置JDK环境变量 在开发过程中,许多应用和框架都需要使用Java,尤其是使用Java开发的应用程序。如果你是Mac用户,以下是安装并配置JDK环境变量的步骤,确保你能顺利运行Java程序。 步骤 1:下载JDK 访…...
【git-hub项目:YOLOs-CPP】本地实现05:项目移植
ok,经过前3个博客,我们实现了项目的跑通。 但是,通常情况下,我们的项目都是需要在其他电脑上也跑通,才对。 然而,经过测试,目前出现了2 个bug。 项目一键下载【⬇️⬇️⬇️】: 精…...
LeetCode 热题 100 206. 反转链表
LeetCode 热题 100 | 206. 反转链表 大家好,今天我们来解决一道经典的算法题——反转链表。这道题在 LeetCode 上被标记为简单难度,要求我们将一个单链表反转,并返回反转后的链表。下面我将详细讲解解题思路,并附上 Python 代码实…...
2025年02月21日Github流行趋势
项目名称:source-sdk-2013 项目地址url:https://github.com/ValveSoftware/source-sdk-2013项目语言:C历史star数:7343今日star数:929项目维护者:JoeLudwig, jorgenpt, narendraumate, sortie, alanedwarde…...
WebXR教学 03 项目1 旋转彩色方块
一、项目结构 webgl-cube/ ├── index.html ├── main.js ├── package.json └── vite.config.js二、详细实现步骤 初始化项目 npm init -y npm install three vite --save-devindex.html <!DOCTYPE html> <html lang"en"> <head><…...
深入解析JVM垃圾回收机制
1 引言 本节常见面试题 如何判断对象是否死亡(两种方法)。简单的介绍一下强引用、软引用、弱引用、虚引用(虚引用与软引用和弱引用的区别、使用软引用能带来的好处)。如何判断一个常量是废弃常量如何判断一个类是无用的类垃圾收…...
【简单】209.长度最小的子数组
题目描述 给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其总和大于等于 target 的长度最小的 子数组 [numsl, numsl1, …, numsr-1, numsr] ,并返回其长度。如果不存在符合条件的子数组,返回0。 示例 1: 输入&am…...
细说 Java 引用(强、软、弱、虚)和 GC 流程(二)
一、前文回顾 在 细说Java 引用(强、软、弱、虚)和 GC 流程(一) 我们对Java 引用有了总体的认识,本文将继续深入分析 Java 引用在 GC 时的一些细节。 还是从我们在前文中提到的引用流程图里说起,这里不清…...
CSS通过webkit-scrollbar设置滚动条样式
查看::-webkit-scrollbar-*各项关系 以下图为例,可以分别定义滚动条背景、滚动轨道、滚动滑块的样式。 需要先给外部容器设置高度,再设置overflow: auto,最后设置三个webkit属性。 <!DOCTYPE html> <html lang"en">…...
5分钟掌握GHelper:华硕笔记本轻量控制工具的实战指南
5分钟掌握GHelper:华硕笔记本轻量控制工具的实战指南 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyrus, Flow, TUF, Strix, Sca…...
从《我的第一份工作》看技术面试:如何避免踩中那些“令人沮丧的旅程”和“最后一根稻草”
技术面试避坑指南:从经典文学拆解职场生存法则 伦敦郊区那所红砖学校的面试经历,放在今天的技术招聘场景中依然能引发强烈共鸣——尴尬的通勤路线、压抑的办公环境、不专业的面试官、模糊的职责描述,这些"面试雷区"穿越半个世纪仍在…...
RyzenAdj:AMD Ryzen 处理器电源管理的终极调优指南
RyzenAdj:AMD Ryzen 处理器电源管理的终极调优指南 【免费下载链接】RyzenAdj Adjust power management settings for Ryzen APUs 项目地址: https://gitcode.com/gh_mirrors/ry/RyzenAdj RyzenAdj 是一款专为 AMD Ryzen 移动处理器设计的开源电源管理工具&a…...
如何快速部署GLM-5-w4a8:Atlas 800T A3上的终极AI推理解决方案
如何快速部署GLM-5-w4a8:Atlas 800T A3上的终极AI推理解决方案 【免费下载链接】GLM-5-w4a8 GLM-5-w4a8基于混合专家架构,专为复杂系统工程与长周期智能体任务设计。支持单/多节点部署,适配Atlas 800T A3,采用w4a8量化技术&#x…...
从‘老王分遗产’到智能指针:用生活例子彻底搞懂C++的dynamic_cast和std::dynamic_pointer_cast
从‘老王分遗产’到智能指针:用生活例子彻底搞懂C的dynamic_cast和std::dynamic_pointer_cast 想象一下,你正在处理一个复杂的家族遗产分配问题。老王有一对儿女——小明和小红,他们各自有不同的财产继承方式。在C的世界里,这种家…...
QuPath选区模式革命:Shift键反选功能如何重塑病理图像标注工作流
QuPath选区模式革命:Shift键反选功能如何重塑病理图像标注工作流 【免费下载链接】qupath QuPath - Open-source bioimage analysis for research 项目地址: https://gitcode.com/gh_mirrors/qu/qupath 在病理图像分析领域,高效精确的细胞核标注是…...
终极指南:5个快速解决Ryujinx模拟器常见问题的完整教程
终极指南:5个快速解决Ryujinx模拟器常见问题的完整教程 【免费下载链接】Ryujinx 用 C# 编写的实验性 Nintendo Switch 模拟器 项目地址: https://gitcode.com/GitHub_Trending/ry/Ryujinx Ryujinx是一款用C#编写的开源Nintendo Switch模拟器,致力…...
pkNX宝可梦ROM编辑器:打造个性化游戏体验的终极指南
pkNX宝可梦ROM编辑器:打造个性化游戏体验的终极指南 【免费下载链接】pkNX Pokmon (Nintendo Switch) ROM Editor & Randomizer 项目地址: https://gitcode.com/gh_mirrors/pk/pkNX 你是否渴望创造独一无二的宝可梦冒险?想要调整游戏难度、自…...
2026届必备的十大降AI率方案推荐
Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 对于学术写作以及内容创作而言,要降低AI生成内容能够被识别出来的概率࿰…...
AGI落地最后一公里卡在哪?SITS2026揭示真相:87.4%的“准AGI”系统在反事实规划任务中F1骤降42.6%,附3步对齐优化路径
第一章:SITS2026发布:AGI能力基准测试 2026奇点智能技术大会(https://ml-summit.org) SITS2026(Singularity Intelligence Test Suite 2026)是首个面向通用人工智能(AGI)系统设计的多模态、跨任务、可演化…...
