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谷题解没看懂就自己做了)

根据性质做题目

  1. 0到n-2一定出现过。
  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]进制位(搜索)的更多相关文章

  1. 洛谷P1013 进制位

    P1013 进制位 题目描述 著名科学家卢斯为了检查学生对进位制的理解,他给出了如下的一张加法表,表中的字母代表数字. 例如: + L K V E L L K V E K K V E KL V V E ...

  2. 洛谷 P1013 进制位

    P1013 进制位 题目描述 著名科学家卢斯为了检查学生对进位制的理解,他给出了如下的一张加法表,表中的字母代表数字. 例如: + L K V E L L K V E K K V E KL V V E ...

  3. 【Luogu】P1013进制位(搜索)

    题目链接在这里 这题和虫食算比较类似.做完这道题可以去做虫食算.都是搜索一类的题. 这样 我们分析题目可以发现进制只可能是字母的个数,也就是n-1.为什么? 因为题目要求完整的加法表才算数.如果进制低 ...

  4. 洛谷 P1013 进制位 【搜索 + 进制运算】

    题目描述 著名科学家卢斯为了检查学生对进位制的理解,他给出了如下的一张加法表,表中的字母代表数字. 例如: + L K V E L L K V E K K V E KL V V E KL KK E E ...

  5. [NOIP1998] 提高组 洛谷P1013 进制位

    题目描述 著名科学家卢斯为了检查学生对进位制的理解,他给出了如下的一张加法表,表中的字母代表数字. 例如: L K V E L L K V E K K V E KL V V E KL KK E E K ...

  6. [洛谷 P1013] NOIP1998 提高组 进制位

    问题描述 著名科学家卢斯为了检查学生对进位制的理解,他给出了如下的一张加法表,表中的字母代表数字. 例如: L K V E L L K V E K K V E KL V V E KL KK E E K ...

  7. P1013 [NOIP1998 提高组] 进制位

    解析 看到这道题时,有没有想到搜索?然后就是一通码......然后过了. 但是,真的要用搜索吗? 我们可以观察一下.对于n进制中的数ii,如果ii加上某一个数jj会变成两位数,那么可以得到如下不等式: ...

  8. 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 ...

  9. [luoguP1013] 进制位(搜索)

    传送门 纯搜索,无优化! #include <cstdio> #include <cstring> #include <iostream> #include < ...

随机推荐

  1. Storm Spout

    本文主要介绍了Storm Spout,并以KafkaSpout为例,进行了说明. 概念 数据源(Spout)是拓扑中数据流的来源.一般 Spout 会从一个外部的数据源读取元组然后将他们发送到拓扑中. ...

  2. SpringBoot(一) 基础入门

    SpringBoot简要 简化Spring应用开发的一个框架: 整个Spring技术栈的一个大整合: J2EE开发的一站式解决方案: 自动配置:针对很多Spring应用程序常见的应用功能,Spring ...

  3. 蛋白质GO信息的一些数据库

    最近用到蛋白质序列数据,但是才发现蛋白质的编号主要分为两种:一种是ENSP开头,主要是在ensembl数据库查询asia.ensembl.org/Human/Search:而另一种是uniprot.w ...

  4. ASM磁盘组中的AU与条带

    一.AU与条带(AU和条带就是一个分配单位,数据会被以一定单位分割,存储在多个磁盘中.分割单位的大小由AU.条带来决定. ASM有两种条带: 1.不可调粗粒度: 相当于ASM没有条带,或者说AU就是条 ...

  5. 优动漫PAINT-绘制透明布料教程

    原是一篇日语教程,觉得挺不错的,就劳烦会日语的朋友帮忙翻译了,特此分享!希望可以帮助到大家在绘画上的学习!原教程转载优动漫官网. 作者:JaneMere 相关资讯还可以关注www.dongmansof ...

  6. [备忘]js-xlsx 操作 Excel 插件

    github地址:https://github.com/SheetJS/js-xlsx oss地址:http://oss.sheetjs.com/js-xlsx/xlsx.full.min.js

  7. VB学习笔记(一)VB操作字符串

    在vb中 dim a# 定义a变量为双精度型变量~ #是类型符 % 整型 & 长整型 !单精度 $ 字符型 VB中strconv 的作用 StrConv("要转换的字符串" ...

  8. WebRTC | Failed to execute 'setLocalDescription' on 'RTCPeerConnection': Failed to parse SessionDescription. a=msid: Missing track ID in msid attribute.

    1.问题回放 使用如下代码获取局域网IP报错 (代码来源:https://github.com/diafygi/webrtc-ips 日期:2019-02-16) Uncaught (in promi ...

  9. ping,telnet,ssh命令的理解

    ping主要用于测试到达目的主机的网络是否连接,但是它不能检测某个端口是否开放. ping 域名可以直接看出这个域名对应的ip ssh与telnet都是远程登录工具. ssh对传输加密,安全性高,te ...

  10. 通过force index了解的MySQL查询的性能优化

    查询是数据库技术中最常用的操作.查询操作的过程比较简单,首先从客户端发出查询的SQL语句,数据库服务端在接收到由客户端发来的SQL语句后, 执行这条SQL语句,然后将查询到的结果返回给客户端.虽然过程 ...