[NOIP1999]进制位(搜索)
P1013 进制位
题目描述
著名科学家卢斯为了检查学生对进位制的理解,他给出了如下的一张加法表,表中的字母代表数字。 例如:
+ L K V E
L L K V E
K K V E KL
V V E KL KK
E E KL KK KV
其含义为:
L+L=L , L+K=K , L+V=V , L+E=E
K+L=K , K+K=V , K+V=E , K+E=KL
…… E+E=KV
根据这些规则可推导出: L=0 , K=1 , V=2 , E=3
同时可以确定该表表示的是4进制加法
//感谢lxy123456同学为本题新加一组数据
输入输出格式
输入格式:
n (n≤9) 表示行数。
以下 n 行,每行包括 n 个字符串,每个字串间用空格隔开。(字串仅有一个为‘+’号,其它都由大写字母组成)
输出格式:
① 各个字母表示什么数,格式如: L=0 , K=1 ,……按给出的字母顺序。
② 加法运算是几进制的。
③ 若不可能组成加法表,则应输出“ERROR!”
输入输出样例
输入样例#1: 复制
5
- L K V E
L L K V E
K K V E KL
V V E KL KK
E E KL KK KV
输出样例#1: 复制
L=0 K=1 V=2 E=3
4
题解
咕咕咕,打打信心题(其实主要是X谷题解没看懂就自己做了)
根据性质做题目
- 0到n-2一定出现过。
- 进制一定是n-1位的
伪证
我要进位啊
仔细想想是不是要有1(前提有0),有1就会有2 and so on.
于是枚举全排列加进制转换就OK了,没什么好讲的。
代码
#include<cstdio>
#include<cstring>
#include<cmath>
#include<iostream>
#include<algorithm>
using namespace std;
int n,vis[11],vi[27];
char s[11][11][11];
int turn(int x,int y){
int ans=0,len=strlen(s[x][y]);
for(int i=0;i<len;i++){
ans=ans*(n-1)+vi[s[x][y][i]-'A'];
//if(x==3&&y==5)cout<<s[x][y][i]<<' ';
}
//if(x==3&&y==5)cout<<endl;
return ans;
}
bool judge()
{
for(int i=2;i<=n;i++)
{
for(int j=2;j<=n;j++)
{
if(i==j&&i==1)continue;
int v1=vi[s[1][i][0]-'A']+vi[s[j][1][0]-'A'],v2=turn(i,j);
if(v1!=v2){/*cout<<v1<<' '<<v2<<' '<<s[1][i][0]<<' '<<s[j][1][0]<<endl;*/return false;}
}
}
return true;
}
void dfs(int step){
if(step==n+1){
// cout<<"Orz"<<endl;
if(judge())
{
for(int i=2;i<=n;i++)
cout<<s[1][i]<<'='<<vi[s[1][i][0]-'A']<<' ';
cout<<endl<<n-1<<endl;
exit(0);
}
/* for(int i=2;i<=n;i++)
cout<<s[1][i][0]<<'='<<vi[s[1][i][0]-'A']<<' ';
cout<<endl;*/
}
for(int i=0;i<n-1;i++)
if(vis[i]==-1)vis[i]=1,vi[s[1][step][0]-'A']=i,dfs(step+1),vis[i]=-1;
}
int main()
{
cin>>n;
memset(vis,-1,sizeof(vis));
// cout<<vis[0]<<endl;
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++){
scanf("%s",s[i][j]);
//if(strlen(s[i][j])==2)vi[s[i][j][1]-'A']=1;
}
dfs(2);
printf("ERROR!\n");
return 0;
}
[NOIP1999]进制位(搜索)的更多相关文章
- 洛谷P1013 进制位
P1013 进制位 题目描述 著名科学家卢斯为了检查学生对进位制的理解,他给出了如下的一张加法表,表中的字母代表数字. 例如: + L K V E L L K V E K K V E KL V V E ...
- 洛谷 P1013 进制位
P1013 进制位 题目描述 著名科学家卢斯为了检查学生对进位制的理解,他给出了如下的一张加法表,表中的字母代表数字. 例如: + L K V E L L K V E K K V E KL V V E ...
- 【Luogu】P1013进制位(搜索)
题目链接在这里 这题和虫食算比较类似.做完这道题可以去做虫食算.都是搜索一类的题. 这样 我们分析题目可以发现进制只可能是字母的个数,也就是n-1.为什么? 因为题目要求完整的加法表才算数.如果进制低 ...
- 洛谷 P1013 进制位 【搜索 + 进制运算】
题目描述 著名科学家卢斯为了检查学生对进位制的理解,他给出了如下的一张加法表,表中的字母代表数字. 例如: + L K V E L L K V E K K V E KL V V E KL KK E E ...
- [NOIP1998] 提高组 洛谷P1013 进制位
题目描述 著名科学家卢斯为了检查学生对进位制的理解,他给出了如下的一张加法表,表中的字母代表数字. 例如: L K V E L L K V E K K V E KL V V E KL KK E E K ...
- [洛谷 P1013] NOIP1998 提高组 进制位
问题描述 著名科学家卢斯为了检查学生对进位制的理解,他给出了如下的一张加法表,表中的字母代表数字. 例如: L K V E L L K V E K K V E KL V V E KL KK E E K ...
- P1013 [NOIP1998 提高组] 进制位
解析 看到这道题时,有没有想到搜索?然后就是一通码......然后过了. 但是,真的要用搜索吗? 我们可以观察一下.对于n进制中的数ii,如果ii加上某一个数jj会变成两位数,那么可以得到如下不等式: ...
- noip 1998 洛谷P1013 进制位
题目描述 著名科学家卢斯为了检查学生对进位制的理解,他给出了如下的一张加法表,表中的字母代表数字. 例如: L K V E L L K V E K K V E KL V V E KL KK E E K ...
- [luoguP1013] 进制位(搜索)
传送门 纯搜索,无优化! #include <cstdio> #include <cstring> #include <iostream> #include < ...
随机推荐
- Core Java(二)
二 .JAVA语言基础 1.注释,标识符,关键字 Comments 用于解释说明程序的文字 Java中注释分类格式 单行注释:格式: //注释文字 多行 ...
- 你不知道的JavaScript(七)delete操作符
JS中的delete操作符不是太常用,容易被忽略,它的作用很简单,用来删除对象的属性或方法. <script type="text/javascript"> var p ...
- JavaScript在不同环境下的全局对象
Node.js 环境下,全局的对象是 global. 浏览器下 window === self 而不是 global,今天才发现的,我惊呆了!
- intellij idea 15 for mac破解版(含注册码)下载
转载 https://blog.csdn.net/dataiyangu/article/details/81163118
- lua中调用C++函数
lua中调用C++函数 我们产品中提供了很多lua-C API给用户在lua中调用,之前一直没用深究其实现原理,只是根据已有的代码在编码.显然这不是一个好的习惯,没用达到知其所以然的目的. 一.基本原 ...
- Visual Studio中C++工程的环境配置方法
在Visual Studio的C++工程设置 1.添加工程的头文件目录:工程---属性---配置属性---c/c++---常规---附加包含目录. 2.添加文件引用的lib静态库路径:工程---属性- ...
- POJ-2752 Seek the Name, Seek the Fame 字符串问题 KMP算法 求前后缀串相同数木
题目链接:https://cn.vjudge.net/problem/POJ-2752 题意 给一个字符串,求前缀串跟后缀串相同的前缀串的个数 例:alala 输出:a, ala, alala 思路 ...
- 学习《数据科学入门》中文PDF+英文PDF+源代码
数据科学是一个蓬勃发展.前途无限的行业,有人将数据科学家称为"21世纪头号性感职业".本书从零开始讲解数据科学工作,教授数据科学工作所必需的黑客技能,并带领读者熟悉数据科学的核心知 ...
- C++ vector基本用法
转自金河http://www.cnblogs.com/wang7/archive/2012/04/27/2474138.html 1 基本操作 (1)头文件#include<vector> ...
- The Karplus-Strong Algorithm
本系列文章由 @YhL_Leo 出品,转载请注明出处. 文章链接: http://blog.csdn.net/yhl_leo/article/details/48730857 Karplus-Stro ...