剑指offer题解合集——Week2day6

剑指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]);
        }
    }
};

思路:

整体思路

快排之前面放奇数,后面放偶数

数组首尾两个指针,不断向中间靠拢
如果是奇数,放在开头,如果是偶数,放在末尾

相关推荐

  1. offer题解——Week2day6

    2024-01-01 06:44:03       43 阅读
  2. offer题解——Week3day2

    2024-01-01 06:44:03       46 阅读
  3. offer题解——Week1day5

    2024-01-01 06:44:03       45 阅读
  4. offer题解——Week1day7

    2024-01-01 06:44:03       50 阅读
  5. offer力扣题

    2024-01-01 06:44:03       18 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-01 06:44:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-01 06:44:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-01 06:44:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-01 06:44:03       18 阅读

热门阅读

  1. C语言之冒泡排序

    2024-01-01 06:44:03       34 阅读
  2. SQL高级:存储过程和触发器

    2024-01-01 06:44:03       36 阅读
  3. Linux常用命令总结

    2024-01-01 06:44:03       35 阅读
  4. MyBatis中#{}和${}的用法

    2024-01-01 06:44:03       37 阅读
  5. [蓝桥杯 2021模拟题] 时间加法

    2024-01-01 06:44:03       40 阅读
  6. Amazon API Gateway CORS 实战

    2024-01-01 06:44:03       30 阅读
  7. zyqn-arm软中断设置

    2024-01-01 06:44:03       39 阅读
  8. [语音识别]开源语音识别faster-whisper模型下载地址

    2024-01-01 06:44:03       39 阅读
  9. QT(C++)-QTableWight添加行和删除空行

    2024-01-01 06:44:03       34 阅读
  10. burpsuite模块介绍之dashboard(仪表板)

    2024-01-01 06:44:03       41 阅读
  11. [NOIP2002 普及组] 级数求和

    2024-01-01 06:44:03       32 阅读