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

剑指offer题解合集——Week2day6

文章目录

  • 剑指offerWeek2
    • 周六:表示数值的字符串
      • AC代码
      • 思路:
    • 周六:调整数组顺序使奇数位于偶数前面
      • AC代码
      • 思路:

剑指offerWeek2

周六:表示数值的字符串

题目链接:表示数值的字符串

请实现一个函数用来判断字符串是否表示数值(包括整数和小数)。例如,字符串"+100","5e2","-123","3.1416"和"-1E-16"都表示数值。但是"12e","1a3.14","1.2.3","+-5"和"12e+4.3"都不是。注意:
小数可以没有整数部分,例如.123等于0.123;
小数点后面可以没有数字,例如233.等于233.0;
小数点前面和后面可以有数字,例如233.666;
当e或E前面没有数字时,整个字符串不能表示数字,例如.e1、e1;
当e或E后面没有整数时,整个字符串不能表示数字,例如12e、12e+5.4;
数据范围
输入字符串长度 [0,25]
字符串中不含空格。样例:
输入: "0"输出: true

AC代码

class Solution {
public:bool isNumber(string s) {int i = 0;while (i < s.size() && s[i] == ' ') i ++ ;int j = s.size() - 1;while (j >= 0 && s[j] == ' ') j -- ;if (i > j) return false;s = s.substr(i, j - i + 1);if (s[0] == '-' || s[0] == '+') s = s.substr(1);if (s.empty() || s[0] == '.' && s.size() == 1) return false;int dot = 0, e = 0;for (int i = 0; i < s.size(); i ++ ){if (s[i] >= '0' && s[i] <= '9');else if (s[i] == '.'){dot ++ ;if (e || dot > 1) return false;}else if (s[i] == 'e' || s[i] == 'E'){e ++ ;if (i + 1 == s.size() || !i || e > 1 || i == 1 && s[0] == '.') return false;if (s[i + 1] == '+' || s[i + 1] == '-'){if (i + 2 == s.size()) return false;i ++ ;}}else return false;}return true;}
};

思路:

整体思路

简单的模拟,不断的特判即可

周六:调整数组顺序使奇数位于偶数前面

题目链接:调整数组顺序使奇数位于偶数前面

输入一个整数数组,实现一个函数来调整该数组中数字的顺序。使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分。数据范围
数组长度 [0,100]
。
数组内元素取值范围 [0,100]
。样例
输入:[1,2,3,4,5]输出: [1,3,5,2,4]

AC代码

class Solution {
public:void reOrderArray(vector<int> &array) {int l = 0, r = array.size() - 1;while (l <= r){while (array[l] % 2 == 1) l ++ ;while (array[r] % 2 == 0) r -- ;if (l < r) swap(array[l], array[r]);}}
};

思路:

整体思路

快排之前面放奇数,后面放偶数数组首尾两个指针,不断向中间靠拢
如果是奇数,放在开头,如果是偶数,放在末尾
http://www.lryc.cn/news/274081.html

相关文章:

  • 算法训练第五十二天|300. 最长递增子序列、674. 最长连续递增序列、718. 最长重复子数组
  • HTTP基础知识总结
  • 创意与技术的结晶:AI魔法绘图与中文描述的完美结合
  • Python:int(value, base=10)
  • Vue之调用store的action(包含getter调用)
  • 蟹目标检测数据集VOC格式400张
  • PyTorch中常用的工具(4)Visdom
  • Linux(ubuntu)下git / github/gitee使用
  • 回归预测 | MATLAB实OOA-LSTM基于鱼鹰优化算法优化长短期记忆网络的多输入单输出数据回归预测模型 (多指标,多图)
  • 2023年工作初体验
  • PostgreSQL 作为向量数据库:入门和扩展
  • 亚信安慧AntDB数据库:企业核心业务系统数据库升级改造的可靠之选
  • CommonJS 和 ES6 Module:一场模块规范的对决(上)
  • python快速实现简易电子音乐盒(电子钢琴)
  • 详解bookkeeper AutoRecovery机制
  • 使用 Ubuntu 20.04 进行初始服务器设置
  • 【SpringCloud】6、Spring Cloud Gateway路由配置
  • pdf转换成word怎么转?一篇文章教你轻松搞定
  • 【中南林业科技大学】计算机组成原理复习包括题目讲解(超详细)
  • 恭喜 Databend 上榜 2023 开源创新榜「优秀开源项目 」
  • 网络连通性批量检测工具
  • 2023高级人工智能期末总结
  • Oracle数据库迁移所有文件到新挂载磁盘路径
  • 基于YOLOv7算法的高精度实时安全背心目标检测识别系统(PyTorch+Pyside6+YOLOv7)
  • Mac——VsCode使用格式化工具进行整理和格式化
  • 73.乐理基础-打拍子-还原号、临时变音记号在简谱中的规则
  • 一款超酷的一体化网站测试工具:Web-Check
  • MockServer简单使用记录
  • AI+金融:大模型引爆金融科技革命
  • 数据库(二)实验一:MySQL数据库的C/S模式部署