leetcode_3.26

1.12. 整数转罗马数字
罗马数字包含以下七种字符: 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 的范围内。
https://leetcode-cn.com/problems/integer-to-roman/
思路:1.贪心算法,一共有13种对应的编码,每次找最大的,直到为0。2.硬编码,因为此题限制在0~3999,因此可以分为四位,每位为对应值是的编码先算出后,查找即可。不如方法一通用
![在这里插入图片描述](https://img-blog.csdnimg.cn/20210326152428493.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubm V0L3dlaXhpbl80NDA3OTE4Ng==,size_16,color_FFFFFF,t_70)
代码:

class Solution {
public:
    string intToRoman(int num) {
        int nums[] = {1000, 900, 500, 400, 100, 90, 50, 40, 10, 9, 5, 4, 1};
        string romans[] = {"M", "CM", "D", "CD", "C", "XC", "L", "XL", "X", "IX", "V", "IV", "I"};
        int i=0;
        string result="";
        while(num!=0){
            int k=num/nums[i];
            for(int j=0;j<k;j++){
                result=result+romans[i];
            }
            num=num%nums[i];
            i++;
        }
        return result;
    }
};
    1. 三数之和
      给你一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?请你找出所有和为 0 且不重复的三元组。
      注意:答案中不可以包含重复的三元组。
      https://leetcode-cn.com/problems/3sum/
      思路:首先排序,因为要求所有结果不能重复,排完序后遇见相同的数跳过就可以保证不存在相同的结果。第一个数从左到右排序,第二个数从第一个数后向右排序,第三个数从右向左排序。但是要大于第二个数,否则会重复,后两个可以采用双指针的原因是因为两者有关系,当后两者相加值小于目标值时,第二个数向右移,反之第三个数向左移,直到两者相遇或不满足第三个在第二个后面。该过程中,若存在则是一个结果。
      注意见到数组下标的++、–一定要加上限制条件!防止访问越界!要不就别用while而用continue!
      代码:
class Solution {
public:
    vector<vector<int>> threeSum(vector<int>& nums) {
        vector<vector<int>> result;
        sort(nums.begin(),nums.end());
        for(int a=0;a<nums.size();a++){
            while(a>0&&nums[a]==nums[a-1]&&a<nums.size()-1){
                a++;
            }
            for(int b=a+1,c=nums.size()-1;b<nums.size()&&b<c;b++){
                while(b>a+1&&nums[b]==nums[b-1]&&b<nums.size()-1){
                    b++;
                }
                while(b<c&&nums[b]+nums[c]>-nums[a]&&c>0){
                    c--;
                }
                if(b==c){
                    break;
                }
                if(nums[b]+nums[c]==-nums[a]){
                    result.push_back(vector<int>{nums[a], nums[b], nums[c]});
                }
            }
        }

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值