力扣刷题(5)

整数转罗马数字

整数转罗马数字-力扣

思路:

  1. 把各十百千位可能出现的情况都列出来,写成一个二维数组
  2. 找出该数的各十百千位,与数组中的罗马元素对应
cpp 复制代码
const char* ch[4][10]={{"", "I", "II", "III", "IV", "V", "VI", "VII", "VIII", "IX"},//个位
                    {"", "X", "XX", "XXX", "XL", "L", "LX", "LXX", "LXXX", "XC"},//十位
                    {"", "C", "CC", "CCC", "CD", "D", "DC", "DCC", "DCCC", "CM"},//百位
                    {"", "M", "MM", "MMM"}};//千位
char* intToRoman(int num) {
    char* str=(char*)malloc(sizeof(char)*16);
    strcpy(str,ch[3][num/1000]);
    strcat(str,ch[2][num/100%10]);
    strcat(str,ch[1][num/10%10]);
    strcat(str,ch[0][num%10]);
    return str;
}

罗马数字转整数

罗马数字转整数-力扣

思路:

  1. 将罗马数字出现的可能写成一个函数,方便后续的判断
  2. 从后往前遍历数组,当这个罗马字母转化成数字后的大小比前一个小,则说明该数字需要减掉,才能符合罗马数字的减法形式
cpp 复制代码
class Solution {
public:
    int change(char ch)
    {
        if(ch == 'I')
            return 1;
        else if(ch == 'V')
            return 5;
        else if(ch == 'X')
            return 10;
        else if(ch == 'L')
            return 50;
        else if(ch == 'C')
            return 100;
        else if(ch == 'D')
            return 500;
        else if(ch == 'M')
            return 1000;
        else
            return 0;
    }

    int romanToInt(string s) {
    int len=s.size()-1;
    int prev=0;
    int sum=0;
    for(len=s.size()-1;len>=0;len--)
    {
        int tmp=change(s[len]);
        prev=prev > tmp ? -tmp:tmp;
        sum+=prev;
    }
    return sum;
    }
};

最长的公共前缀

最长的公共前缀-力扣


思路来源:灵茶山艾府

  1. 从左到右遍历 strs 的每一列。
  2. 设当前遍历到第 j 列,从上到下遍历这一列的字母。
  3. 设当前遍历到第 i 行,即 strs[i][j]。如果 j 等于 strs[i] 的长度,或者 strs[i][j] != strs[i][0],说明这一列的字母缺失或者不全一样,那么最长公共前缀的长度等于 j,返回 strs[0] 的长为 j 的前缀。
  4. 如果没有中途返回,说明所有字符串都有一个等于 strs[0] 的前缀,那么最长公共前缀就是 strs[0]。
c 复制代码
char* longestCommonPrefix(char** strs, int strsSize) {
    char* str=strs[0];
    for(int j=0;str[j];j++)
    {
        for(int i=0;i<strsSize;i++)
        {
            if(strs[i][j] != str[j])
            {
                str[j]='\0';
                return str;
            }
        }
    }
    return str;
}
相关推荐
Ricky111zzz1 天前
leetcode学python记录1
python·算法·leetcode·职场和发展
逆境不可逃1 天前
LeetCode 热题 100 之 230. 二叉搜索树中第 K 小的元素 199. 二叉树的右视图 114. 二叉树展开为链表
算法·leetcode·职场和发展
wfbcg1 天前
每日算法练习:LeetCode 15. 三数之和 ✅
算法·leetcode·职场和发展
y = xⁿ1 天前
【LeetCode Hot100】双指针:分离指针
算法·leetcode
6Hzlia1 天前
【Hot 100 刷题计划】 LeetCode 41. 缺失的第一个正数 | C++ 原地哈希题解
c++·leetcode·哈希算法
小肝一下1 天前
每日两道力扣,day6
数据结构·c++·算法·leetcode·双指针·hot100
人道领域1 天前
【LeetCode刷题日记】242.字母异位词
算法·leetcode·职场和发展
XWalnut1 天前
LeetCode刷题 day8
算法·leetcode·职场和发展
Ricky111zzz1 天前
leetcode学python记录2
python·算法·leetcode·职场和发展
会编程的土豆1 天前
【数据结构与算法】堆排序
开发语言·数据结构·c++·算法·leetcode