双指针 leetcode

本文介绍了力扣(LeetCode)中涉及字符串反转及数组搜索的三种算法解决方案。第一部分讲解如何仅反转字母,使用双指针策略。第二部分提供了两种寻找有序数组中目标和的下标的解法,包括遍历加二分查找和双指针法。第三部分是版本号比较,转换字符串为数字并进行比较。这些题目涉及字符串处理、数组操作和版本号比较等核心算法知识。
摘要由CSDN通过智能技术生成

力扣 仅仅反转字母

class Solution {
public:
    string reverseOnlyLetters(string s) {
        int n=s.size();
        int left=0,right=n-1;
        while(left<right)
        {
            if(s[left]>='a'&&s[left]<='z'||s[left]>='A'&&s[left]<='Z')
            {
                if(s[right]>='a'&&s[right]<='z'||s[right]>='A'&&s[right]<='Z')
                {
                    char c=s[left];
                    s[left]=s[right];
                    s[right]=c;
                    left++;
                    right--;
                }
                else{
                    right--;
                }
            }
            else{
                left++;
            }
        }
        return s;
    }
};

用 left 指针从左边开始扫描字符串 s,right 指针从右边开始扫描字符串 s。如果两个指针都扫描到字母,且 left<right,那么交换 s[left] 和 s[right],然后继续进行扫描;否则表明反转过程结束,返回处理后的字符串。

167. 两数之和 II - 输入有序数组

 方法一:

class Solution {
public:
    vector<int> twoSum(vector<int>& numbers, int target) {
        int n=numbers.size();
        for(int i=0;i<n;i++)
        {
            int number=target-numbers[i];
            if(number>numbers[n-1]||number<numbers[i]) continue;
            else{
                int left=i,right=n;
                while(left+1!=right)
                {
                    int mid=(left+right)/2;
                    if(numbers[mid]>number) right=mid;
                    else left=mid;
                }
                if(numbers[left]==number) return {i+1,left+1};
            }
        }
        return {};
    }
};

利用遍历加二分查找的方法来做

方法二:

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

 利用双指针靠近法

165. 比较版本号

class Solution {
public:
    int compareVersion(string version1, string version2) {
        int n = version1.length(), m = version2.length();
        int i = 0, j = 0;
        while (i < n || j < m) {
            long long x = 0;
            for (; i < n && version1[i] != '.'; ++i) {
                x = x * 10 + version1[i] - '0';
            }
            ++i; // 跳过点号
            long long y = 0;
            for (; j < m && version2[j] != '.'; ++j) {
                y = y * 10 + version2[j] - '0';
            }
            ++j; // 跳过点号
            if (x != y) {
                return x > y ? 1 : -1;
            }
        }
        return 0;
    }
};

 引用了官方的题解,官方的题解对x,y的定义为int型已经无法通过全部测试样例,需要改成长整型。

思路的话就是字符chuan转数字然后数字进行比大小

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值