剑指offer21.调整数组顺序使得奇数位于偶数前面 57.和为s的两个数字 58.反转单词顺序

本文主要是介绍剑指offer21.调整数组顺序使得奇数位于偶数前面 57.和为s的两个数字 58.反转单词顺序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述
暴力二次遍历(时间复杂度空间复杂度都是n)

class Solution {
public:vector<int> exchange(vector<int>& nums) {vector<int> result(nums.size());int left=0;for(int i=0;i<nums.size();i++){if(nums[i]%2==1) result[left++]=nums[i];}for(int i=0;i<nums.size();i++){if(nums[i]%2==0) result[left++]=nums[i];}return result;}
};

这边有一个问题 ,就是如果这个vector result(nums.size()) 不知道长度 那插入数组时候只能用result.push_back(nums[i])
只有在我定义里这vector容器长度n的时候。我才能使用result[i]
这是不定义长度的写法

class Solution {
public:vector<int> exchange(vector<int>& nums) {vector<int> result;for(int i=0;i<nums.size();i++){if(nums[i]%2==1) result.push_back(nums[i]);}for(int i=0;i<nums.size();i++){if(nums[i]%2==0) result.push_back(nums[i]);}return result;}
};

方法2:双指针,一次遍历,原地修改
时间n 空间1

class Solution {
public:vector<int> exchange(vector<int>& nums) {int left=0,right=1;while(right<nums.size()){if(nums[left]%2==1||nums[right]%2==1)//left和right至少有一个为奇数{if(nums[left]%2==0)//前偶后奇 调换{int temp=nums[left];nums[left]=nums[right];nums[right]=temp;}//其他情况 比如前奇后偶 前奇后奇 都不需要调换 直接++left++;right++;}else //全为偶数{right++;}}return nums;}
};

在这里插入图片描述
无语 写了个哈希集合 然后就大无语,耗时耗空间
我想的是先把当前数组放到哈希表里,然后再遍历当前数组的时候,在哈希集合里找有没有和他配对的,有就放进result里面
在这里插入图片描述

class Solution {
public:vector<int> twoSum(vector<int>& nums, int target) {unordered_set<int>set;vector<int>result;for(int i=0;i<nums.size();i++) set.insert(nums[i]);for(int i=0;i<nums.size();i++){if(set.count(target-nums[i])!=0){result={nums[i],target-nums[i]};}}return result;}
};

优化哈希表(记住 这是一个排过序的 所以找到后面大的 大的对应的target-x一定是前面已经存储在哈希容器里的。(其实和没优化的差距不大哈哈哈哈)

class Solution {
public:vector<int> twoSum(vector<int>& nums, int target) {unordered_set<int>set;for(auto x:nums){if(set.count(target-x)!=0) return {x,target-x};set.insert(x);}return {};}
};

方法2:双指针 和三数之和很像,只是不用去重

class Solution {
public:vector<int> twoSum(vector<int>& nums, int target) {int left=0,right=nums.size()-1;while(left<right){if(nums[left]+nums[right]>target) right--;else if(nums[left]+nums[right]==target) return{nums[left],nums[right]};else left++;}return {};}
};

在这里插入图片描述
调用stringstream

class Solution {
public:string reverseWords(string s) {string res = "",temp;stringstream ss(s);while(ss >> temp){res = temp + " " + res;//temp读取s里每一个单词}res.pop_back();return res;}
};

方法2:暴力解法
整体翻转+局部一个一个翻转(要求每个单词中间只能用一个空格连接)
思路 找空格 截取当前单词的0到空格 拼接直到再也找不到空格
问题:1.要去除字符串前面所有的空格 2.去除字符串整体翻转后所有的空格 3.去除字符串中间单词的空格 比如 a good example 。
举例:” a good example “
1.首先去除前面的空格->” a good example “
2.整体翻转->” elpmaxe doog a “,去除前面的空格->” elpmaxe doog a “
3.第一次找空格elpmaxe后面 截取出来翻转->“example”,substr=example,result+=example,s截取变成” doog a“去除中间的空格->”doog a“
4.第二次找空格 截取 翻转”good“,substr=good;result=example good,s变成a,此时其实是找不到空格的,那条件判定就会出现问题,因此要在大循环while (s.find(" ") != s.npos)判断前,去除首位空格后,在s尾部加一个空格,这样到第四步就变成了 s=”a “
5.第三次找空格,a后面,翻转即本身,substr=a,result=a good example s啥也解决不到了
循环结束!!!

class Solution {
public:
string reverseWords(string s) {string result, substr;int len = s.size();int pos = 0;while (s[0] == ' '){len--;s = s.substr(1, len);}//去除前面的空格reverse(s.begin(), s.end());//整个字符串翻转int i = 0;while (s[0] == ' '){len--;s = s.substr(1, len);}//去除翻转后前面的空格s += " ";//后面加个空格cout<<s<<endl;len++;int flag = 0;while (s.find(" ") != s.npos){int j = 0;if (flag != 0) result+= " ";flag=1;//就是指示第一个不用加空格,下面单词拼接都要用的pos = s.find(" ");substr = s.substr(0, pos);reverse(substr.begin(), substr.end());result += substr;s = s.substr(pos+1 , len - pos - 1);len=s.size();while (s[0] == ' '){len--;s = s.substr(1, len);}//去除中间的空格}return result;
}
};

这篇关于剑指offer21.调整数组顺序使得奇数位于偶数前面 57.和为s的两个数字 58.反转单词顺序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/803464

相关文章

springboot控制bean的创建顺序

《springboot控制bean的创建顺序》本文主要介绍了spring-boot控制bean的创建顺序,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录1、order注解(不一定有效)2、dependsOn注解(有效)3、提前将bean注册为Bea

Java数组动态扩容的实现示例

《Java数组动态扩容的实现示例》本文主要介绍了Java数组动态扩容的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1 问题2 方法3 结语1 问题实现动态的给数组添加元素效果,实现对数组扩容,原始数组使用静态分配

Java中ArrayList与顺序表示例详解

《Java中ArrayList与顺序表示例详解》顺序表是在计算机内存中以数组的形式保存的线性表,是指用一组地址连续的存储单元依次存储数据元素的线性结构,:本文主要介绍Java中ArrayList与... 目录前言一、Java集合框架核心接口与分类ArrayList二、顺序表数据结构中的顺序表三、常用代码手动

JavaScript对象转数组的三种方法实现

《JavaScript对象转数组的三种方法实现》本文介绍了在JavaScript中将对象转换为数组的三种实用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录方法1:使用Object.keys()和Array.map()方法2:使用Object.entr

JAVA实现亿级千万级数据顺序导出的示例代码

《JAVA实现亿级千万级数据顺序导出的示例代码》本文主要介绍了JAVA实现亿级千万级数据顺序导出的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 前提:主要考虑控制内存占用空间,避免出现同时导出,导致主程序OOM问题。实现思路:A.启用线程池

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

python 线程池顺序执行的方法实现

《python线程池顺序执行的方法实现》在Python中,线程池默认是并发执行任务的,但若需要实现任务的顺序执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录方案一:强制单线程(伪顺序执行)方案二:按提交顺序获取结果方案三:任务间依赖控制方案四:队列顺序消

基于Python实现数字限制在指定范围内的五种方式

《基于Python实现数字限制在指定范围内的五种方式》在编程中,数字范围限制是常见需求,无论是游戏开发中的角色属性值、金融计算中的利率调整,还是传感器数据处理中的异常值过滤,都需要将数字控制在合理范围... 目录引言一、基础条件判断法二、数学运算巧解法三、装饰器模式法四、自定义类封装法五、NumPy数组处理

Java中数组与栈和堆之间的关系说明

《Java中数组与栈和堆之间的关系说明》文章讲解了Java数组的初始化方式、内存存储机制、引用传递特性及遍历、排序、拷贝技巧,强调引用数据类型方法调用时形参可能修改实参,但需注意引用指向单一对象的特性... 目录Java中数组与栈和堆的关系遍历数组接下来是一些编程小技巧总结Java中数组与栈和堆的关系关于

Spring Bean初始化及@PostConstruc执行顺序示例详解

《SpringBean初始化及@PostConstruc执行顺序示例详解》本文给大家介绍SpringBean初始化及@PostConstruc执行顺序,本文通过实例代码给大家介绍的非常详细,对大家的... 目录1. Bean初始化执行顺序2. 成员变量初始化顺序2.1 普通Java类(非Spring环境)(