力扣解题(简单)

一、两数之和

给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。
你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。
示例:
给定 nums = [2, 7, 11, 15], target = 9
因为 nums[0] + nums[1] = 2 + 7 = 9 所以返回 [0, 1]

解答:

class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
        int i = 0;
        int j = 0;
        vector<int> a;
        for (i = 0; i < nums.size(); i ++)
        {
            for (j = i+1 ; j < nums.size(); j ++)
            {
                if(nums[i] + nums[j] == target)
                {
                    a.push_back(i);
                    a.push_back(j);
                    break;
                }                
            }
        }
        return a;
}  
};

执行用时 :320 ms, 在所有 C++ 提交中击败了23.23%的用户
内存消耗 :9 MB, 在所有 C++ 提交中击败了98.65%的用户

二、整数反转

给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。
示例 1:
输入: 123 输出: 321
示例 2:
输入: -123 输出: -321
示例 3:
输入: 120 输出: 21
假设我们的环境只能存储得下 32 位的有符号整数,则其数值范围为 [−231, 231 − 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。

注意假设,要在返回前检查是否有溢出!
解答

class Solution {
public:
    int reverse(int x) {
        long a = 0;
         
        
        while(x!=0)
        {
            if (a > INT_MAX/10 || (a == INT_MAX / 10 && x > 7)) 
             return 0;
            if (a < INT_MIN/10 || (a == INT_MIN / 10 && x < -8)) 
             return 0;
            a = a*10+x%10;
            x = x/10;
        }
        return a;
    }
};

执行用时 :4 ms, 在所有 C++ 提交中击败了93.29%的用户
内存消耗 :8.2 MB, 在所有 C++ 提交中击败了81.65%的用户

三、回文数

判断一个整数是否是回文数。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。

示例 1:
输入: 121 输出: true

示例 2:
输入: -121 输出: false 解释: 从左向右读, 为 -121 。 从右向左读, 为 121- 。因此它不是一个回文数。

示例3:
输入: 10 输出: false 解释: 从右向左读, 为 01 。
因此它不是一个回文数。

解答:

class Solution {
public:
    bool isPalindrome(int x) {
        if( x < 0)
        {
            return false;
        }
        int t =x;
        long a = 0;
        while(x!=0)
        {
            a=a*10+x%10;
            x=x/10;
        }
        if (a==t)
            return true;
        else
            return false;
        
    }
};

执行用时 :4 ms, 在所有 C++ 提交中击败了99.74%的用户
内存消耗 :8.1 MB, 在所有 C++ 提交中击败了84.42%的用户

四、罗马数字转整数

这个程序是把字符串倒着输出检测的。

罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。

字符 数值 I 1 V 5 X 10 L
50 C 100 D 500 M 1000 例如, 罗马数字 2
写做 II ,即为两个并列的 1。12 写做 XII ,即为 X + II 。 27 写做 XXVII, 即为 XX + V + II 。

通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5
的左边,所表示的数等于大数 5 减小数 1 得到的数值 4 。同样地,数字 9 表示为 IX。这个特殊的规则只适用于以下六种情况:

I 可以放在 V (5) 和 X (10) 的左边,来表示 4 和 9。 X 可以放在 L (50) 和 C (100) 的左边,来表示
40 和 90。 C 可以放在 D (500) 和 M (1000) 的左边,来表示 400 和 900。
给定一个罗马数字,将其转换成整数。输入确保在 1 到 3999 的范围内。

示例 1:

输入: “III” 输出: 3 示例 2:

输入: “IV” 输出: 4 示例 3:

输入: “IX” 输出: 9 示例 4:

输入: “LVIII” 输出: 58 解释: L = 50, V= 5, III = 3. 示例 5:

输入: “MCMXCIV” 输出: 1994 解释: M = 1000, CM = 900, XC = 90, IV = 4.

class Solution {
public:
    int romanToInt(string s) {
        	int l =s.size();
	int max=0,num=0;
	for(int i=l-1;i>=0;i--)
	{
		switch(s[i])
		{
		case 'I':
			if(max>0)
				num-=1;
			else
				num+=1;
			break;
		case 'V':
			max=5;
			num+=5;
			break;
		case 'X':
			if(max>10)
				num-=10;
			else
			{
				num+=10;
				max = 10;
			}
			break;
		case 'L':
			max=50;
			num+=50;
			break;
		case 'C':
			if(max>100)
				num-=100;
			else
			{
				max =100;
				num+=100;
			}
			break;
		case 'D':
			max=500;
			num+=500;
			break;
		case 'M':
			max=1000;
			num+=1000;
			break;
		default:
			cout<<"输入错误!!!";
		}
	}
	return num;
    }
};

五、有效括号

给定一个只包括 ‘(’,’)’,’{’,’}’,’[’,’]’ 的字符串,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
注意空字符串可被认为是有效字符串。
示例 1:
输入: “()” 输出: true
示例 2:
输入: “()[]{}” 输出: true
示例 3:
输入: “(]” 输出: false
示例 4:
输入: “([)]” 输出: false
示例 5:
输入: “{[]}” 输出: true

解答

class Solution {
public:
    bool isValid(string s) {
        int a = s.size();
        stack <char> temp;
        temp.push('x');
        for (int i = 0; i < a; i++)
        {
            if (temp.top() + 1 == s[i] || temp.top() +2 == s[i])
            {
                temp.pop();
                continue;
            }
            temp.push(s[i]);
        }
        if(temp.top()=='x')
            return true;
        else
            return false;
    }
};

六、 删除排序数组中的重复项

给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。
不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。
示例 1:
给定数组 nums = [1,1,2],
函数应该返回新的长度 2, 并且原数组 nums 的前两个元素被修改为 1, 2。
你不需要考虑数组中超出新长度后面的元素。
示例 2:
给定 nums = [0,0,1,1,1,2,2,3,3,4],
函数应该返回新的长度 5, 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4。
你不需要考虑数组中超出新长度后面的元素。
说明:
为什么返回数值是整数,但输出的答案是数组呢?
请注意,输入数组是以“引用”方式传递的,这意味着在函数里修改输入数组对于调用者是可见的。
你可以想象内部操作如下:
// nums 是以“引用”方式传递的。也就是说,不对实参做任何拷贝
int len = removeDuplicates(nums);
// 在函数里修改输入数组对于调用者是可见的。
// 根据你的函数返回的长度, 它会打印出数组中该长度范围内的所有元素。
for (int i = 0; i < len; i++) {
print(nums[i]);
}

** 解答**


class Solution {
public:
    int removeDuplicates(vector<int>& nums) {
        
       if(nums.size()==0) return 0;
        int k=0;
        for(int i=1;i<nums.size();i++)
        if(nums[i]!=nums[k])
            nums[++k]=nums[i];
        return ++k;
    }
};

思路:若前后重复则不进行操作,如前后不一致,则将后者的数据复制给前者,这样输出的就不会是重复的数据。
在这里插入图片描述

七、移除元素

给定一个数组 nums 和一个值 val,你需要原地移除所有数值等于 val 的元素,返回移除后数组的新长度。
不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。
元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。
示例 1:
给定 nums = [3,2,2,3], val = 3,
函数应该返回新的长度 2, 并且 nums 中的前两个元素均为 2。
你不需要考虑数组中超出新长度后面的元素。
示例 2:
给定 nums = [0,1,2,2,3,0,4,2], val = 2,
函数应该返回新的长度 5, 并且 nums 中的前五个元素为 0, 1, 3, 0, 4。
注意这五个元素可为任意顺序。
你不需要考虑数组中超出新长度后面的元素。
说明:
为什么返回数值是整数,但输出的答案是数组呢?
请注意,输入数组是以“引用”方式传递的,这意味着在函数里修改输入数组对于调用者是可见的。
你可以想象内部操作如下:
// nums 是以“引用”方式传递的。也就是说,不对实参作任何拷贝
int len = removeElement(nums, val);
// 在函数里修改输入数组对于调用者是可见的。
// 根据你的函数返回的长度, 它会打印出数组中该长度范围内的所有元素。
for (int i = 0; i < len; i++) {
print(nums[i]);
}

解答

class Solution {
public:
    int removeElement(vector<int>& nums, int val) {
         auto it = nums.begin();
        while(it!=nums.end()){
            if(*it==val){
                it = nums.erase(it);
            }
            else{
                ++it;
            }
        }
        return nums.size();
        
    }
};

八、实现 strStr() 函数。

给定一个 haystack 字符串和一个 needle 字符串,在 haystack 字符串中找出 needle 字符串出现的第一个位置
(从0开始)。如果不存在,则返回 -1。

示例 1:

输入: haystack = “hello”, needle = “ll” 输出: 2

示例 2:

输入: haystack = “aaaaa”, needle = “bba” 输出: -1

说明:

当 needle 是空字符串时,我们应当返回什么值呢?这是一个在面试中很好的问题。

对于本题而言,当 needle 是空字符串时我们应当返回 0 。这与C语言的 strstr() 以及 Java的 indexOf()
定义相符。

解答:

class Solution {
public:
    int strStr(string haystack, string needle) {
        int n=haystack.length(), m=needle.length();
        vector<int> next(m+1);
        next[0]=-1;
        int i, k=-1, j=0;
        while(j<m)
        {
            if(k==-1 || needle[k]==needle[j])
            {
                k++;
                j++;
                next[j]=k;
            }
            else
                k=next[k];
        }// 先把next数组完成。
        
        i=0, j=0;
        while(i<n && j<m)
        {
            if(j==-1 || haystack[i]==needle[j])
            {
                i++;
                j++;
            }
            else
                j=next[j];
        }
        if(j==m)
            return i-j;
        else
            return -1;
    }
};

九、搜索插入位置

给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
你可以假设数组中无重复元素。
示例 1:
输入: [1,3,5,6], 5
输出: 2
示例 2:
输入: [1,3,5,6], 2
输出: 1
示例 3:
输入: [1,3,5,6], 7
输出: 4
示例 4:
输入: [1,3,5,6], 0
输出: 0

解答:

class Solution
{
public:
    int searchInsert(vector<int>& nums, int target) 
    {
        int i;
        for(i = 0; i < nums.size(); ++i)
        {
            if(target <= nums[i])
                return i;            
        }
        return i;
    }
};

十、 最大子序和

给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。

示例:

输入: [-2,1,-3,4,-1,2,1,-5,4], 输出: 6 解释: 连续子数组 [4,-1,2,1] 的和最大,为 6。

解答:(在力扣上出现:Line 922: Char 34: runtime error: reference binding to null pointer of type 'value_type' (stl_vector.h) 不知道怎么解决 但是在我自己的编译器上是成功的)

#include<iostream>
#include <vector>
using namespace std;
int main()
{
       int nums[9]={-2,-1,-3,4,-1,2,-1,-5,-4};
       int i = nums.size();
       int j = 0;
       int k = 0;
       vector<int> a;
	   for (j=0;j<i-1;j++)
        {
             int sum = 0;
             for (k=j;k<i-1;k++)
            {
                sum = nums[k]+sum;
               a.push_back(sum);
            }
        }
             int max = a[0];
             for (int b= 0; b < a.size();b++)
               {
                   if (a[b]>max)
                   {
                       max = a[b];
                   }
               }
        cout << max << endl;
        return 0;
}

没什么技巧性 就是把所有的和写入一个数组,然后找数组中的最大值。

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值