题目链接:

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. ThreadX——IPC应用之信号量

    一.应用简介 在RTOS的应用开发中,信号量也是经常使用到的一种用于多任务之间信息同步.资源互斥访问的一种手段,常用于协调多个任务访问同一资源的场景.信号量又分为计数信号量和互斥信号量.计数信号量可以 ...

  2. 标注工具labelimg和labelme

    矩形标注工具:labelimg 多边形标准工具:labelme 前者官网发布了可执行文件,后者只有python源码,如果需要编译windows exe,可以这样: pip install labelm ...

  3. Oracle数据泵常用命令

    导读:expdp和impdp是oracle数据库之间移动数据的工具,本文简单总结了数据泵的常用命令,希望对大家有帮助.   前言 expdp和impdp是oracle数据库之间移动数据的工具.expd ...

  4. Angular入门,开发环境搭建,使用Angular CLI创建你的第一个Angular项目

    前言: 最近一直在使用阿里的NG-ZORRO(Angular组件库)开发公司后端的管理系统,写了一段时间的Angular以后发现对于我们.NET后端开发而言真是非常的友善.因此这篇文章主要是对这段时间 ...

  5. Centos上配置nginx+uwsgi+负载均衡配置

    负载均衡在服务端开发中算是一个比较重要的特性.因为Nginx除了作为常规的Web服务器外,还会被大规模的用于反向代理后端,Nginx的异步框架可以处理很大的并发请求,把这些并发请求hold住之后就可以 ...

  6. HCIP----静态实验

    要求: 1.全网可达 2.拓扑中所需地址全部基于192.168.0.0/24划分所得 3.使用静态路由 4.R1有三个环回,需要汇总 5.PC1与PC3属于同一VLAN,PC2和PC4属于同一VLAN ...

  7. 用python写注入漏洞的poc

    webug靶场一道简单的注入题 加点后报错 could not to the database You have an error in your SQL syntax; check the manu ...

  8. 手写简易版RPC框架基于Socket

    什么是RPC框架? RPC就是远程调用过程,实现各个服务间的通信,像调用本地服务一样. RPC有什么优点? - 提高服务的拓展性,解耦.- 开发人员可以针对模块开发,互不影响.- 提升系统的可维护性及 ...

  9. [leetcode]罗马数字和阿拉伯数字相互转换

    罗马转阿拉伯 public int romanToInt(String s) { /* 从左到右依次根据哈希表进行加法 如果是"CM"900这种情况就要执行+M和-C处理 */ i ...

  10. Idea利用maven创建web项目,并配置tomcat

    参考http://blog.csdn.net/myarrow/article/details/50824793#comments