Codevs 1064 虫食算 2004年NOIP全国联赛提高组
1064 虫食算 2004年NOIP全国联赛提高组
时间限制: 2 s
空间限制: 128000 KB
题目等级 : 钻石 Diamond
题目描述 Description
所谓虫食算,就是原先的算式中有一部分被虫子啃掉了,需要我们根据剩下的数字来判定被啃掉的字母。来看一个简单的例子:
43#9865#045
+ 8468#6633
44445506978
其中#号代表被虫子啃掉的数字。根据算式,我们很容易判断:第一行的两个数字分别是5和3,第二行的数字是5。
现在,我们对问题做两个限制:
首先,我们只考虑加法的虫食算。这里的加法是N进制加法,算式中三个数都有N位,允许有前导的0。
其次,虫子把所有的数都啃光了,我们只知道哪些数字是相同的,我们将相同的数字用相同的字母表示,不同的数字用不同的字母表示。如果这个算式是N进制的,我们就取英文字母表午的前N个大写字母来表示这个算式中的0到N-1这N个不同的数字:但是这N个字母并不一定顺序地代表0到N-1)。输入数据保证N个字母分别至少出现一次。
BADC
+ CBDA
DCCC
上面的算式是一个4进制的算式。很显然,我们只要让ABCD分别代表0123,便可以让这个式子成立了。你的任务是,对于给定的N进制加法算式,求出N个不同的字母分别代表的数字,使得该加法算式成立。输入数据保证有且仅有一组解,
输入描述 Input Description
输入包含4行。第一行有一个正整数N(N<=26),后面的3行每行有一个由大写字母组成的字符串,分别代表两个加数以及和。这3个字符串左右两端都没有空格,从高位到低位,并且恰好有N位。
输出描述 Output Description
输出包含一行。在这一行中,应当包含唯一的那组解。解是这样表示的:输出N个数字,分别表示A,B,C……所代表的数字,相邻的两个数字用一个空格隔开,不能有多余的空格。
样例输入 Sample Input
5
ABCED
BDACE
EBBAA
样例输出 Sample Output
1 0 3 4 2
数据范围及提示 Data Size & Hint
对于30%的数据,保证有N<=10;
对于50%的数据,保证有N<=15;
对于全部的数据,保证有N<=26。
分类标签 Tags
深度优先搜索 搜索 大陆地区 NOIP全国联赛提高组 2004年
/*
考试的时候没想到剪枝.
只有40分QWQ.
*/
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#define MAXN 30
using namespace std;
int s[4][MAXN],c[4][MAXN];
int n,a[MAXN];
bool b[MAXN];
int read(){
int x=0,f=1;char ch;ch=getchar();
while(ch<'0'||ch>'9') {if(ch=='-') f=-1;ch=getchar();}
while(ch>='0'&&ch<='9') x=x*10+ch-48,ch=getchar();
return x*f;
}
void check(){
int p=0;
for(int i=1;i<=3;i++)
for(int j=1;j<=n;j++){
c[i][j]=a[s[i][j]];
}
for(int j=n;j>=1;j--){
p=(c[1][j+1]+c[2][j+1]+p)/n;
if((c[1][j]+c[2][j]+p)%n!=c[3][j]) return;
}
for(int i=1;i<=n-1;i++){
printf("%d ",a[i]);
}
printf("%d",a[n]);
exit(0);
}
void dfs(int t){
if(t==n+1) {check();return ;}
for(int i=0;i<n;i++)
if(!b[i])b[i]=1,a[t]=i,dfs(t+1),b[i]=0;
}
void slove(){
dfs(1);
}
int main(){
n=read();char ch;
for(int i=1;i<=3;i++)
for(int j=1;j<=n;j++){
cin>>ch;s[i][j]=ch-64;
}
slove();
return 0;
}
/*
搜素+显然的剪枝
全排列时加剪枝.
由题意:
当我们全部知道某位是否进位时,
就可以唯一的确定一组答案.
判断当前字母以前是否出现过判错.
进位数最多为 1.
所以直接(a+b)%n==c||(a+b+1)%n==c;
从右往左,按照字母出现顺序搜索.
*/
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#define MAXN 30
using namespace std;
int s[4][MAXN],c[4][MAXN],w[MAXN*MAXN];
int n,a[MAXN],tot;
bool b[MAXN];
int read(){
int x=0,f=1;char ch;ch=getchar();
while(ch<'0'||ch>'9') {if(ch=='-') f=-1;ch=getchar();}
while(ch>='0'&&ch<='9') x=x*10+ch-48,ch=getchar();
return x*f;
}
void check(){
int p=0;
for(int j=n;j>=1;j--){
p=(a[s[1][j+1]]+a[s[2][j+1]]+p)/n;
if((a[s[1][j]]+a[s[2][j]]+p)%n!=a[s[3][j]]) return;
}
for(int i=1;i<=n-1;i++){
printf("%d ",a[i]);
}
printf("%d",a[n]);
exit(0);
}
bool jd(){
for(int i=n;i>=1;i--){
if(a[s[1][i]]!=-1&&a[s[2][i]]!=-1&&a[s[3][i]]!=-1){
if((a[s[1][i]]+a[s[2][i]]+1)%n==a[s[3][i]]||(a[s[1][i]]+a[s[2][i]])%n==a[s[3][i]]) continue;
return false;
}
}
return true;
}
void dfs(int t){
if(t==n+1) {check();return ;}
for(int i=0;i<n;i++){
if(!b[i]){
b[i]=1,a[w[t]]=i;
if(jd())dfs(t+1);
b[i]=0;a[w[t]]=-1;
}
}
}
void slove(){
dfs(1);
}
int main(){
n=read();char ch;
for(int i=1;i<=3;i++)
for(int j=1;j<=n;j++){
cin>>ch;s[i][j]=ch-64;
if(!a[ch-64]){
a[ch-64]=-1;w[++tot]=ch-64;
}
}
slove();
return 0;
}
Codevs 1064 虫食算 2004年NOIP全国联赛提高组的更多相关文章
- 虫食算 2004年NOIP全国联赛提高组(dfs)
1064 虫食算 2004年NOIP全国联赛提高组 时间限制: 2 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题解 查看运行结果 题目描述 Descrip ...
- codevs 1058 合唱队形 2004年NOIP全国联赛提高组
1058 合唱队形 2004年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description N位同学站成一排,音 ...
- 【CodeVS】【2004年NOIP全国联赛提高组】1057 津津的储蓄计划
1057 津津的储蓄计划 2004年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 青铜 Bronze 题目描述 Description 津津的零花钱一直都是 ...
- 1058 合唱队形 2004年NOIP全国联赛提高组
1058 合唱队形 2004年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 查看运行结果 题目描述 Descripti ...
- Codevs 1173 最优贸易 2009年NOIP全国联赛提高组
1173 最优贸易 2009年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description [问题描述] C 国有n ...
- Codevs 1066 引水入城 2010年NOIP全国联赛提高组
1066 引水入城 2010年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 传送门 题目描述 Description 在一个遥远的国度 ...
- 深度优先搜索 codevs 1064 虫食算
codevs 1064 虫食算 2004年NOIP全国联赛提高组 时间限制: 2 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 所 ...
- codevs 1057 津津的储蓄计划 2004年NOIP全国联赛提高组 x
时间限制: 1 s 空间限制: 128000 KB 题目描述 Description 津津的零花钱一直都是自己管理.每个月的月初妈妈给津津300元钱,津津会预算这个月的花销,并且总能做到实际花 ...
- 津津的储蓄计划 2004年NOIP全国联赛提高组
题目描述 Description 津津的零花钱一直都是自己管理.每个月的月初妈妈给津津300元钱,津津会预算这个月的花销,并且总能做到实际花销和预算的相同. 为了让津津学习如何储蓄,妈妈提出,津津可以 ...
随机推荐
- Linux设备驱动中的异步通知与异步I/O
异步通知概念: 异步通知的意识是,一旦设备就绪,则主动通知应用程序,这样应用程序根本就不需要查询设备状态,这一点非常类似于硬件上的“中断”概念,比较准确的称谓是“信号驱动的异步IO”,信号是在软件层次 ...
- HDU2196 - Computer(树形DP)
题目大意 给定一颗n个结点的树,编号为1~n,要求你求出每个结点能到达的最长路径 题解 用动态规划解决的~~~~把1 当成树根,这样就转换成有根树了.我们可以发现,对于每个结点的最长路,要么是从子树得 ...
- npm 国内镜像资源 --转载
npm 是node.js 环境下的包管理器,非常强大智能. 生活这这片神奇的土地上,各种奇葩手段屡见不鲜啊. 为什么要换源? npm 官方站点 http://www.npmjs.org/ 并没有被墙, ...
- 问题-RZ安装后报错“RzBorder.pas”
错误象现:[Error] RzBorder.pas(1429): Number of elements differs from declaration [Fatal Error] RzEdit.pa ...
- setTimeout中0毫秒延时
先来看段代码,思考一下执行的结果. alert(1); setTimeout(function(){alert(2);}, 0); alert(3); 估计很多人认为执行结果为1,2,3,原因就是认为 ...
- phpstorm映射远程项目
项目要设置为default,否则自动更新会失败:type要选正确 development path和web path都要设置 options选项中选ctrl+s自动保存,且下方没告警
- JAVA之装饰者模式
装饰模式又名包装(Wrapper)模式.装饰模式以对客户端透明的方式扩展对象的功能,是继承关系的一个替代方案. 装饰模式的结构 装饰模式以对客户透明的方式动态地给一个对象附加上更多的责任.换言之,客户 ...
- 关闭utorrent的广告
版本:3.4.9 / 方法来源:wikihow. 在"选项-高级"里将下面的选项全部改成false. offers.left_rail_offer_enabledoffers.sp ...
- 解决libcrypto.so.0.9.8: cannot open shared object file
文章解决的问题:安装nginx中需要libmysql.so.16包的支持,下面介绍如何安装,并建立lib的连接. 问题展示:error while loading shared libraries: ...
- jstl前台Jsp日期格式化
1. 引入fmt标签 <%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt" %&g ...