力扣 12 整数转罗马数字 C++

题目

知识点

C++标准库utility

题目解释

题解

逐位编码------低位到高位

answer = substr + answer;//不可以交换位置!!!

复制代码
class Solution {
public:
    string intToRoman(int num) {
        string answer = "";//存放最终结果
        int mo;//mo存放当前要处理的数字
        int d = 0;//d表示当前正处理第d位(个位 十位 百位)
        char ch_10[] = { 'I','X','C','M' };//1个位  10十位  100  1000
        char ch_5[] = { 'V','L','D' };//5个位  50十位  500

        while(num > 0){
            string substr = "";//临时存放当前位的处理结果
            mo = num % 10;
            if(mo == 4){//4 IV
                substr = substr + ch_10[d] + ch_5[d];//4 IV 1在前,5在后
            }else if(mo == 9){//9 IX
                substr = substr + ch_10[d] + ch_10[d + 1];//9 IX 1在前,10在后
            }else if(mo >= 5 && mo <= 8){
                substr.insert(substr.begin(),ch_5[d]);//将字符ch_5[d]插入到字符串substr的开头
                for(int i=0 ; i<(mo-5) ;i++){
                    substr = substr + ch_10[d];//在substr后面加上表示1的字符------I
                }
            }else{
                for(int i=0;i<mo;i++){
                    substr = substr + ch_10[d];
                }
            }
            answer = substr + answer;//不可以交换位置!!!
            d++;
            num /= 10;
        }//while

        return answer;
    }
};

大数查表法------高位到低位

复制代码
const pair<int, string> valueSymbols[] = {
	{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"},
};

class Solution {
public:
	string intToRoman(int num) {
		string roman;
		for (const auto& [value, symbol] : valueSymbols) {
			while (num >= value) {
				num -= value;
				roman += symbol;
			}
			if (num == 0) {
				break;
			}
		}
		return roman;
	}
};
相关推荐
2401_873479403 小时前
如何利用IP查询定位识别电商刷单?4个关键指标+工具配置方案
开发语言·tcp/ip·php
我爱cope3 小时前
【从0开始学设计模式-10| 装饰模式】
java·开发语言·设计模式
菜鸟学Python3 小时前
Python生态在悄悄改变:FastAPI全面反超,Django和Flask还行吗?
开发语言·python·django·flask·fastapi
浪浪小洋4 小时前
c++ qt课设定制
开发语言·c++
charlie1145141914 小时前
嵌入式C++工程实践第16篇:第四次重构 —— LED模板,从通用GPIO到专用抽象
c语言·开发语言·c++·驱动开发·嵌入式硬件·重构
handler014 小时前
Linux: 基本指令知识点(2)
linux·服务器·c语言·c++·笔记·学习
故事和你914 小时前
洛谷-数据结构1-4-图的基本应用1
开发语言·数据结构·算法·深度优先·动态规划·图论
程序猿编码5 小时前
给你的网络流量穿件“隐形衣“:手把手教你用对称加密打造透明安全隧道
linux·开发语言·网络·安全·linux内核
aq55356006 小时前
编程语言三巨头:汇编、C++与PHP大比拼
java·开发语言
aq55356006 小时前
PHP vs Python:30秒看懂核心区别
开发语言·python·php