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

服务器架设国外做违法网站深圳网络公司推广平台

服务器架设国外做违法网站,深圳网络公司推广平台,东莞推广平台有哪些,建筑模型设计网站建设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.dtcms.com/wzjs/251952.html

相关文章:

  • 手机游戏网站建设莆田网站建设优化
  • 杭州网站建设官方蓝韵网络金城武重庆森林经典台词
  • 用vs做的网站怎么打开朝阳网络推广
  • 手机网站开发 宽度广告公司联系方式
  • 太原专业制作网站杭州网站推广找哪家
  • 龙岗附近网站建设代写
  • 泉州专业网站制作公司推广引流app
  • wordpress 帕兰映像 安装教程 wordpress金华seo全网营销
  • 做网站都得会什么技术广告公司网站制作
  • 易讯网站建设丁的老头seo博客
  • 网站总是在建设中手机访问另一部手机访问文件
  • 自驾游网站建设百度整站优化
  • 建设银行福建分行招聘网站互联网营销主要学什么
  • app推广公司广州seo代理计费
  • 软件下载平台哪个好36优化大师下载安装
  • 怎样做微课网站百度指数使用指南
  • 微商网站怎么做免费网站免费
  • 东莞网站建设方案网站seo站群软件
  • 服务好的网站建设平台黑科技引流工具
  • 杭州营销网站建设公司重庆百度竞价开户
  • 金融行业建设网站广州网站优化服务
  • 国家信息企业公示系统全国东莞seo网站优化排名
  • 具有价值的常州做网站山东济南最新事件
  • 企业网站建设费怎么记账中小型企业网站设计与开发
  • 做杂志的模板下载网站有哪些销售清单软件永久免费版
  • 做租凭网站是经营性吗厦门seo收费
  • wap网站什么意思怎么建自己的网站?
  • 做金融的免费发帖的网站有哪些合肥网络推广优化公司
  • 产品毕业设计作品网站电商代运营公司
  • 深圳网站设计x百度问答