题目链接:

https://vjudge.net/problem/UVA-185

思路:

剪枝、回溯

注意回溯的时候,是从当前点的下一个开始,而不是从已经遍历的个数点开始!!不然回溯有问题!

思路参考自https://blog.csdn.net/HelloWorld10086/article/details/38778361

  1 #include <iostream>
2 #include<cstdio>
3 #include<map>
4 #include<set>
5 #include<cstring>
6 #include<string>
7 using namespace std;
8 map<char,int> mp,mp2;
9 string s1,s2,sum;
10 int vis[2000];
11 int size,count=0;
12 const char letter[]="IXCMVLD";
13 int head[2000];
14
15 int change(string number){
16 int ans=mp[number[number.size()-1]];
17 for(int i=number.size()-2;i>=0;i--){
18 if(mp[number[i]]<mp[number[i+1]])
19 ans-=mp[number[i]];
20 else
21 ans+=mp[number[i]];
22 }
23 return ans;
24 }
25 int judge2(string a,string b,string c){
26 int num1,num2,ans;
27 int tmp=1;
28 for(int i=a.size()-1;i>=0;i--){
29 num1+=mp2[a[i]]*tmp;
30 tmp*=10;
31 }
32 }
33 int trans(string s){
34 int tmp=1,ans=0;
35 for(int i=s.size()-1;i>=0;i--){
36 ans+=tmp*mp2[s[i]];
37 tmp*=10;
38 }
39 return ans;
40 }
41 void dfs(int cur,int cnt){
42 if(cnt==size){
43 if(trans(s1)+trans(s2)==trans(sum)) {
44 count++;
45 }
46 return;
47 }
48 if(count>1) return;
49 for(int i=cur;i<7;i++){
50 if(vis[letter[i]]){
51 for(int j=0;j<=9;j++){
52 if(!vis[j]){//letter[i]<-j
53
54 if(j==0&&head[letter[i]])
55 continue;
56
57 vis[j]=1;
58
59 mp2[letter[i]]=j;//想象成一个数组,不用再回溯
60
61 // dfs(cur+1,cnt+1);
62 dfs(i+1,cnt+1);//不是下一位,不然回溯有问题!!
63
64 vis[j]=0;
65
66 if(count>1)
67 return;
68 }
69 }
70 }
71 }
72 }
73 void init(){
74 mp2.clear();
75 memset(vis,0,sizeof(vis));
76 memset(head,0,sizeof(head));
77 size=0;count=0;
78
79 mp['I']=1;mp['X']=10;mp['C']=100;mp['M']=1000;
80 mp['V']=5;mp['L']=50;mp['D']=500;
81 }
82 int main(int argc, char** argv) {
83 string line;
84 while(cin>>line){
85 if(line[0]=='#') break;
86 init();
87
88 int ind1,ind2;
89 for(int i=0;i<line.size();i++){
90 if(line[i]=='+') {
91 ind1=i;
92 s1=line.substr(0,ind1);
93 }
94 else if(line[i]=='='){
95 ind2=i;
96 s2=line.substr(ind1+1,ind2-ind1-1);
97 }
98 else if(!vis[line[i]]){
99 vis[line[i]]=1;
100 size++;
101 }
102 }
103 sum=line.substr(ind2+1);
104
105 head[s1[0]]=1;head[s2[0]]=1;head[sum[0]]=1;
106
107 if(change(s1)+change(s2)==change(sum)){
108 printf("Correct ");
109 }else{
110 printf("Incorrect ");
111 }
112 dfs(0,0);
113 if(count>1) printf("ambiguous\n");
114 else if(count==1) printf("valid\n");
115 else printf("impossible\n");
116
117 }
118 return 0;
119 }

UVA - 185 Roman Numerals的更多相关文章

  1. Project Euler 89:Roman numerals 罗马数字

    Roman numerals For a number written in Roman numerals to be considered valid there are basic rules w ...

  2. UVA 185(暴力DFS)

      Roman Numerals  The original system of writing numbers used by the early Romans was simple but cum ...

  3. Roman numerals

    Roman numerals 罗马数字的题目, 注意几个关键的数字即可: (100, 400, 500, 900) -> ('C', 'CD', 'D', 'CM'); (10, 40, 50, ...

  4. Project Euler:Problem 89 Roman numerals

    For a number written in Roman numerals to be considered valid there are basic rules which must be fo ...

  5. CodeForcesGym 100641D Generalized Roman Numerals

    Generalized Roman Numerals Time Limit: 5000ms Memory Limit: 262144KB This problem will be judged on  ...

  6. Roman Numerals All In One

    Roman Numerals All In One 罗马数字 refs https://www.mathsisfun.com/roman-numerals.html https://www.maths ...

  7. UVa 130 - Roman Roulette

    模拟约瑟夫环  Roman Roulette  The historian Flavius Josephus relates how, in the Romano-Jewish conflict  o ...

  8. UVA题目分类

    题目 Volume 0. Getting Started 开始10055 - Hashmat the Brave Warrior 10071 - Back to High School Physics ...

  9. [LeetCode] Roman to Integer 罗马数字转化成整数

    Given a roman numeral, convert it to an integer. Input is guaranteed to be within the range from 1 t ...

随机推荐

  1. Unity 保存游戏,读取游戏,退出游戏

    1 using System.Collections; 2 using System.Collections.Generic; 3 using UnityEngine; 4 using System. ...

  2. 点击劫持(Iframe clickJack)练习

    实验内容: 寻找一个合适的网站放入到iframe标签中.实验中测试了包括知网首页及登录界面.淘宝首页及登录界面,百度首页,微信下载界面.发现淘宝登录界面无法放入,会直接跳转到淘宝真实的登录界面,其他的 ...

  3. .NET5 API 网关Ocelot+Consul服务注册

    1|0网关介绍 网关其实就是将我们写好的API全部放在一个统一的地址暴露在公网,提供访问的一个入口.在 .NET Core下可以使用Ocelot来帮助我们很方便的接入API 网关.与之类似的库还有Pr ...

  4. python初学者-判断今天是今年的第几天代码

    判断今天是今年的第几天源代码 import time date =time.localtime() year,month,day=date[:3] day_month=[31,28,31,30,31, ...

  5. 红黑树规则,TreeSet原理,HashSet特点,什么是哈希值,HashSet底层原理,Map集合特点,Map集合遍历方法

    ==学习目标== 1.能够了解红黑树 2.能够掌握HashSet集合的特点以及使用(特点以及使用,哈希表数据结构) 3.能够掌握Map集合的特点以及使用(特点,常见方法,Map集合的遍历) 4.能够掌 ...

  6. Java面试被经常问到的常用算法

    一.冒泡排序 原理:比较两个相邻的元素,较大的放在右边 N个数字要排序完成,总共进行N-1趟排序,每i趟的排序次数为(N-i)次 最好时间复杂度为O(N) Cmax = N(N-1)/2 = O(N2 ...

  7. 智能BPOS小票模板字体的使用

    关于伯俊智能BPOS零售小票模板的设置,常用字体"黑体"."宋体"."Arial"这几个字体,在设置的时候看似没有问题, 但是在正真使用打印 ...

  8. 不是RESTful不好,是你姿势有问题

    文章来源:https://ningyu1.github.io/site/post/01-restful-design-specifications/ 一. 摘要(Abstract) RESTful A ...

  9. 图解HTTP权威指南(四)| 代理

    作者简介 李先生(Lemon),高级运维工程师(自称),SRE专家(目标),梦想在35岁买一辆保时捷.喜欢钻研底层技术,认为底层基础才是王道.一切新技术都离不开操作系统(CPU.内存.磁盘).网络等. ...

  10. MySQL不会丢失数据的秘密,就藏在它的 7种日志里

    本文收录在 GitHub 地址 https://github.com/chengxy-nds/Springboot-Notebook 进入正题前先简单看看MySQL的逻辑架构,相信我用的着. MySQ ...