当前位置: 首页 > news >正文

色彩设计网站sem分析是什么意思

色彩设计网站,sem分析是什么意思,连云港网站建设价格,如何登录qq网页版LeetCode12_整数转罗马数字 标签:#哈希表 #数字 #字符串Ⅰ. 题目Ⅱ. 示例 0. 个人方法:模拟官方题解二:硬编码数字 标签:#哈希表 #数字 #字符串 Ⅰ. 题目 七个不同的符号代表罗马数字,其值如下: 符号值I…

LeetCode12_整数转罗马数字

  • 标签:#哈希表 #数字 #字符串
    • Ⅰ. 题目
    • Ⅱ. 示例
  • 0. 个人方法:模拟
  • 官方题解二:硬编码数字

标签:#哈希表 #数字 #字符串

Ⅰ. 题目

  • 七个不同的符号代表罗马数字,其值如下:
符号
I1
V5
X10
L50
C100
D500
M1000
  • 罗马数字是通过添加从最高到最低的小数位值的转换而形成的。将小数位值转换为罗马数字有以下规则:

  • 如果该值不是以 4 或 9 开头,请选择可以从输入中减去的最大值的符号,将该符号附加到结果,减去其值,然后将其余部分转换为罗马数字。

  • 如果该值以 4 或 9 开头,使用 减法形式,表示从以下符号中减去一个符号,例如 4 是 5 (V) 减 1 (I): IV ,9 是 10 (X) 减 1 (I):IX。仅使用以下减法形式:4 (IV),9 (IX),40 (XL),90 (XC),400 (CD) 和 900 (CM)。

  • 只有 10 的次方(I, X, C, M)最多可以连续附加 3 次以代表 10 的倍数。你不能多次附加 5 (V),50 (L) 或 500 (D)。如果需要将符号附加4次,请使用 减法形式。

  • 给定一个整数,将其转换为罗马数字。

Ⅱ. 示例

· 示例 1:
输入:num = 3749
输出: “MMMDCCXLIX”
解释:
3000 = MMM 由于 1000 (M) + 1000 (M) + 1000 (M)
700 = DCC 由于 500 (D) + 100 © + 100 ©
40 = XL 由于 50 (L) 减 10 (X)
9 = IX 由于 10 (X) 减 1 (I)
注意:49 不是 50 (L) 减 1 (I) 因为转换是基于小数位

· 示例 2:
输入:num = 58
输出:“LVIII”
解释:
50 = L
8 = VIII

· 示例 3:
输入:num = 1994
输出:“MCMXCIV”
解释:
1000 = M
900 = CM
90 = XC
4 = IV

0. 个人方法:模拟

class Solution {
public:string intToRoman(int num) {std::vector<std::pair<int, std::string>> renoma_map = {{1000, "M"}, {900, "CM"}, {500, "D"}, {400, "CD"}, {100, "C"},{90, "XC"}, {50, "L"}, {40, "XL"}, {10, "X"}, {9, "IX"}, {5, "V"}, {4, "IV"}, {1, "I"}};std::string roma = "";for (const auto& pair : renoma_map){while (num >= pair.first){roma += pair.second;  // 添加符号num -= pair.first;    // 减去对应的值}}return roma;}
};

(官方题解一,即上述模拟,因此跳过)

官方题解二:硬编码数字

在这里插入图片描述
在这里插入图片描述

  • 利用模运算和除法运算,我们可以得到 num 每个位上的数字:
thousands_digit = num / 1000
hundreds_digit = (num % 1000) / 100
tens_digit = (num % 100) / 10
ones_digit = num % 10
  • 最后,根据 num 每个位上的数字,在硬编码表中查找对应的罗马字符,并将结果拼接在一起,即为 num 对应的罗马数字。
const string thousands[] = {"", "M", "MM", "MMM"};
const string hundreds[]  = {"", "C", "CC", "CCC", "CD", "D", "DC", "DCC", "DCCC", "CM"};
const string tens[]      = {"", "X", "XX", "XXX", "XL", "L", "LX", "LXX", "LXXX", "XC"};
const string ones[]      = {"", "I", "II", "III", "IV", "V", "VI", "VII", "VIII", "IX"};class Solution {
public:string intToRoman(int num) {return thousands[num / 1000] + hundreds[num % 1000 / 100] + tens[num % 100 / 10] + ones[num % 10];}
};
  • 复杂度分析

  • 时间复杂度:O(1)。计算量与输入数字的大小无关。

  • 空间复杂度:O(1)。

http://www.cadmedia.cn/news/14289.html

相关文章:

  • 事业单位网站建设的作用软件开发公司排名
  • 大连全套网站建设seo和网络推广有什么区别
  • 怀化政法网站青岛网站建设公司
  • 自己怎么在电脑上做网站网络广告形式
  • 伊春网站建设公司百度怎么发帖做推广
  • 网站制作验收单深圳优化seo
  • 有没有免费的推广网站百度竞价培训
  • 广安市建设局网站泉州seo培训
  • 郑州网站设计排行竞价托管公司排名
  • 学校网站平台建设方案外链seo
  • 聊城专业网站建设公司哪家好百度网站推广价格查询
  • 广告公司会建设网站吗怎么让自己上百度
  • 网站定制公司地址合肥seo代理商
  • 智慧团建注册登录入口手机版下载手机管家一键优化
  • 漯河网站建设电话网站seo诊断分析报告
  • 关于企业网站建设的必要性北京seo公司排名
  • 北京网站开发费用厦门关键词排名优化
  • 查找全国免费网站建设刺激广告
  • 北京网站建设友情链接有什么用
  • 网站 建设开发合同模板互联网医疗的营销策略
  • 室内设计中文网南宁白帽seo技术
  • 网格建设专业好不好苏州网站关键词优化推广
  • 大数据网站建设和白帽seo
  • dw做网站教程百度收录情况
  • 柳州网站建设找哪家好郑州网站技术顾问
  • 国内好的seo太原seo推广
  • 广州网站优化电话百度搜索大数据怎么查
  • 临沂网站建设goldball网络推广页面
  • 网站建设入门基础补习班
  • 济南建网站市场调研报告怎么做