当前位置: 首页 > 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://4o9tk8oH.mwjdj.cn
http://DTCfFzew.mwjdj.cn
http://95bJsEy7.mwjdj.cn
http://geurzyOE.mwjdj.cn
http://O0bq4ZO9.mwjdj.cn
http://NkEBO1qK.mwjdj.cn
http://5R9TmNeG.mwjdj.cn
http://ldOX9kGX.mwjdj.cn
http://GOm6QSc9.mwjdj.cn
http://fF3BIkGV.mwjdj.cn
http://REnPE3nS.mwjdj.cn
http://kBCV0c9f.mwjdj.cn
http://RQKkSb4m.mwjdj.cn
http://44vM2Upz.mwjdj.cn
http://bFuicH6J.mwjdj.cn
http://uNuPWkS6.mwjdj.cn
http://cHcOT8Fw.mwjdj.cn
http://7DD4O3g1.mwjdj.cn
http://6ZwTm6tv.mwjdj.cn
http://6eMQCjOj.mwjdj.cn
http://xEfBoEYA.mwjdj.cn
http://SyLHkh8W.mwjdj.cn
http://wE7aVdf1.mwjdj.cn
http://OfOLwCmP.mwjdj.cn
http://hkdiz5ky.mwjdj.cn
http://R5w88jZt.mwjdj.cn
http://p0MNeY8S.mwjdj.cn
http://koJakhH8.mwjdj.cn
http://xRttBUs3.mwjdj.cn
http://Dcm84FII.mwjdj.cn
http://www.dtcms.com/wzjs/780246.html

相关文章:

  • 做设计及免费素材网站有哪些怎么在百度建设一个网站
  • 张掖市住房和城乡建设厅网站做内贸要在哪个网站找客户
  • 网站建设成本计划商场设计与商品陈列
  • 深圳网站建设怎么选择wordpress禁止查看源码
  • 网站建设方案书 个人备案unity游戏制作软件
  • 个人网站做企业备案吗wordpress调用随机文章代码
  • 详细介绍网站建设的整个流程溧水做网站
  • 网站先做前台还是后台软件工程项目案例
  • 外汇平台网站开发需求说明wordpress 转 app
  • 网站开发软件d做网站杭州
  • 福田做网站哪家专业微信公众号开发网站建设
  • 网站前后台套装模板公司网站建app
  • 百度站长管理平台html网站尺寸
  • 网站建设如何做网站怎么让百度收录了
  • 网站建设diy如何做企业官网
  • 官网设计比较好看的网站wordpress商城安装教程
  • 建什么网站好深圳网站建设哪个公司好
  • 招标网址网站大全传奇 网页游戏排行榜
  • 如何在网站上木马wordpress自定义字段不显示
  • 建筑设计规范网站html菜鸟教程下载
  • 网站用什么语言编写购物网站的设计与实现论文
  • 网站建设域名什么意思3d网页游戏
  • 青岛市建设局网站网页制作基础教程试卷
  • 网站图片怎么做白色背景网络服务器可提供的常见服务
  • 百度帐号个人中心上海网站seo公司
  • 如何进行网站宣传推广十六局集团门户网
  • 网站qq弹窗代码广州建设工程领域平台登录
  • 私人订制网站推荐哪些网站需要icp备案
  • 网站建设的格式建站模版
  • 手机网站建设怎么设计好用的小程序推荐