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

罗马数字转整数-力扣通过自己编译器编译

 学会将力扣题目用自己自带的编译软件编译---纯自己想的本题解法

字符          数值
I             1
V             5
X             10
L             50
C             100
D             500
M             1000

例如, 罗马数字 2 写做 II ,即为两个并列的 1 。12 写做 XII ,即为 X + II 。 27 写做  XXVII, 即为 XX + V + II 。

通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数值 4 。同样地,数字 9 表示为 IX。这个特殊的规则只适用于以下六种情况:

  • I 可以放在 V (5) 和 X (10) 的左边,来表示 4 和 9。
  • X 可以放在 L (50) 和 C (100) 的左边,来表示 40 和 90。 
  • C 可以放在 D (500) 和 M (1000) 的左边,来表示 400 和 900。

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

方法一:模拟

思路

通常情况下,罗马数字中小的数字在大的数字的右边。若输入的字符串满足该情况,那么可以将每个字符视作一个单独的值,累加每个字符对应的数值即可。

  • 时间复杂度:O(n)O(n)O(n),其中 nnn 是字符串 sss 的长度。

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

#include<stdio.h>
#include<string.h>
#include<stdlib.h>

 
int romanToInt(char* s) {
    int len = strlen(s);
    int sum=0;
    for(int i=0;i<len;i++){
    	if(s[i]=='I' && s[i+1]=='V'){
    		sum += 4;
    		i++;
		}else 
		if(s[i]=='I' && s[i+1]=='X'){
    		sum += 9;
    		i++;
		}else
		if(s[i]=='X' && s[i+1]=='L'){
    		sum += 40;
    		i++;
		}else
		if(s[i]=='X' && s[i+1]=='C'){
    		sum += 90;
    		i++;
		}else
		if(s[i]=='C' && s[i+1]=='D'){
    		sum += 400;
    		i++;
		}else
		if(s[i]=='C' && s[i+1]=='M'){
    		sum += 900;
    		i++;
		}else{
			switch(s[i]){
				case 'I':sum += 1; break;
				case 'V':sum += 5; break;
				case 'X':sum += 10; break;
				case 'L':sum += 50; break;
				case 'C':sum += 100; break;
				case 'D':sum += 500; break;
				case 'M':sum += 1000; break;
			}
		}
	}
	return sum;
}



int main(){
	char a[]="MCMXCIV";
    printf("%d",romanToInt(a));
    return 0;
}

 学会将力扣题目用自己自带的编译软件编译

字符          数值
I             1
V             5
X             10
L             50
C             100
D             500
M             1000

例如, 罗马数字 2 写做 II ,即为两个并列的 1 。12 写做 XII ,即为 X + II 。 27 写做  XXVII, 即为 XX + V + II 。

通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数值 4 。同样地,数字 9 表示为 IX。这个特殊的规则只适用于以下六种情况:

  • I 可以放在 V (5) 和 X (10) 的左边,来表示 4 和 9。
  • X 可以放在 L (50) 和 C (100) 的左边,来表示 40 和 90。 
  • C 可以放在 D (500) 和 M (1000) 的左边,来表示 400 和 900。

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

方法一:模拟

思路

通常情况下,罗马数字中小的数字在大的数字的右边。若输入的字符串满足该情况,那么可以将每个字符视作一个单独的值,累加每个字符对应的数值即可。

  • 时间复杂度:O(n)O(n)O(n),其中 nnn 是字符串 sss 的长度。

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

#include<stdio.h>
#include<string.h>
#include<stdlib.h>

 
int romanToInt(char* s) {
    int len = strlen(s);
    int sum=0;
    for(int i=0;i<len;i++){
    	if(s[i]=='I' && s[i+1]=='V'){
    		sum += 4;
    		i++;
		}else 
		if(s[i]=='I' && s[i+1]=='X'){
    		sum += 9;
    		i++;
		}else
		if(s[i]=='X' && s[i+1]=='L'){
    		sum += 40;
    		i++;
		}else
		if(s[i]=='X' && s[i+1]=='C'){
    		sum += 90;
    		i++;
		}else
		if(s[i]=='C' && s[i+1]=='D'){
    		sum += 400;
    		i++;
		}else
		if(s[i]=='C' && s[i+1]=='M'){
    		sum += 900;
    		i++;
		}else{
			switch(s[i]){
				case 'I':sum += 1; break;
				case 'V':sum += 5; break;
				case 'X':sum += 10; break;
				case 'L':sum += 50; break;
				case 'C':sum += 100; break;
				case 'D':sum += 500; break;
				case 'M':sum += 1000; break;
			}
		}
	}
	return sum;
}



int main(){
	char a[]="MCMXCIV";
    printf("%d",romanToInt(a));
    return 0;
}

#include<stdio.h>
#include<string.h>
#include<stdlib.h>

 
int romanToInt(char* s) {
    int len = strlen(s);
    int sum=0;
    for(int i=0;i<len;i++){
        if(s[i]=='I' && s[i+1]=='V'){
            sum += 4;
            i++;
        }else
        if(s[i]=='I' && s[i+1]=='X'){
            sum += 9;
            i++;
        }else
        if(s[i]=='X' && s[i+1]=='L'){
            sum += 40;
            i++;
        }else
        if(s[i]=='X' && s[i+1]=='C'){
            sum += 90;
            i++;
        }else
        if(s[i]=='C' && s[i+1]=='D'){
            sum += 400;
            i++;
        }else
        if(s[i]=='C' && s[i+1]=='M'){
            sum += 900;
            i++;
        }else{
            switch(s[i]){
                case 'I':sum += 1; break;
                case 'V':sum += 5; break;
                case 'X':sum += 10; break;
                case 'L':sum += 50; break;
                case 'C':sum += 100; break;
                case 'D':sum += 500; break;
                case 'M':sum += 1000; break;
            }
        }
    }
    return sum;
}

int main(){
    char a[]="MCMXCIV";
    printf("%d",romanToInt(a));
    return 0;
}


http://www.kler.cn/a/273208.html

相关文章:

  • Hive自定义函数—剔除周日周六(小时级别)
  • react18中redux-promise搭配redux-thunk完美简化异步数据操作
  • torchvision.io.write_video 报错替换
  • AI打造超写实虚拟人物:是科技奇迹还是伦理挑战?
  • Java中每个类都有个Class对象,那Class类有自己的Class对象吗?
  • IMU应用于监测进食
  • 计算机网络之网络层概念整理(上)
  • 算法笔记p328_并查集
  • LeetCode350:两个数组的交集Ⅱ
  • 腾讯云优惠券领取指南:让你省钱又省心
  • 文件系统I/O FATFS RW 源码分析
  • win修改图标自定义QQ桌面图标
  • 粤嵌6818开发板通过MobaXterm使用SSH连接开发板
  • 前端入职配置新电脑!!!
  • 力扣思路题:最长特殊序列1
  • kingbase 服务器配置(参数修改)
  • 关于学习的一点粗浅见解
  • Linux TCP参数——tcp_adv_win_scale
  • luceda ipkiss教程 63:器件端口延伸ExtendPorts
  • C++——字符串、读写文件、结构体、枚举
  • 【人工智能】英文学习材料03(每日一句)
  • 【字符串算法题】541. 反转字符串 II
  • es 聚合操作(二)
  • openstack迁移虚拟机--来自gpt
  • kerberos验证协议安装配置使用
  • 6语言交易所/多语言交易所php源码/微盘PHP源码