P1092 虫食算
题目传送:https://www.luogu.org/problem/show?pid=1092
#include <iostream> #include <cstring> #include <cstdlib> #include <cstdio> #include <cmath> #define maxn 30 int n,flag[maxn]; ][maxn]; bool use[maxn]; int id(char ch)//将字符串转换为数字 { ; } void dfs(int x,int y,int t)//x代表列,y代表行,t代表进位 { ) //从上到下,从右到左,x==0表示搜到了最后一列 { )//最后一列不能有进位,如果进了以为则第三个字符串会比其他两个字符串长一位 { ;i<n;i++) //如果满足条件,就输出 printf("%d ",flag[i]);//输出 printf("%d\n",flag[n]);//输出 exit(); //相当于return 0;程序结束 } return;//返回 } ;i>=;i--) //剪枝1 { ][i])];//w1表示第一行字符串代表的数字 ][i])];//w2表示第二行字符串代表的数字 ][i])];//w3表示第三行字符串代表的数字 ||w2==-||w3==-) //如果这个位置上还没被赋值,就返回 continue; )%n!=w3) return; //如果无论进位与否,都不能整除对应的w3就说明字符串不匹配,直接return ; } ) ////如果这个位置上还没被赋值,就进行赋值操作 { ;i>=;i--) //倒着枚举更快 if (!use[i]) //如果这个数没有用过 { ) //且不是最后一行 { flag[id(s[y][x])]=i;//就将这个位置赋上值 use[i]=;//标记这个数用过 dfs(x,y+,t);//继续搜索下一行 flag[id(s[y][x])]=-;//还原 use[i]=;//还原 } else //当y==3时 { ][x])]+flag[id(s[][x])]+t;//两个数加上它们的进位 if (w%n!=i) continue; use[i]=;flag[id(s[][x])]=i;//赋值,标记这个数用过 dfs(x-,,w/n);//搜索下一列,进位需要改变 use[i]=;flag[id(s[][x])]=-;//还原 } } } else //如果这个位置上已经被赋值了 { ) //继续搜索 dfs(x,y+,t); else { ][x])]+flag[id(s[][x])]+t; ][x])]) //剪枝 2 return; dfs(x-,,w/n);//搜索下一列,进位需要改变 } } } int main() { scanf("%d",&n);//读入n,代表n进制等...... ;i<=;i++) scanf();//读入3行字符串 memset(flag,-,sizeof(flag));//将所有位置标记为未赋值 dfs(n,,);//从右往左,上往下搜索,所有从第n列,第1行开始 ;//结束 }
P1092 虫食算的更多相关文章
- 洛谷P1092 虫食算
P1092 虫食算 题目描述 所谓虫食算,就是原先的算式中有一部分被虫子啃掉了,需要我们根据剩下的数字来判定被啃掉的字母.来看一个简单的例子: http://paste.ubuntu.com/2544 ...
- 【题解】 P1092虫食算
[题解]P1092 虫食算 老题了,很经典. 用到了一些搜索套路. 可行性剪枝,劣者靠后,随机化,\(etc......\) 搜索设参也很有技巧,设一个\(adjustment\)参数可以很方便地在两 ...
- Luogu P1092 虫食算(枚举+剪枝)
P1092 虫食算 题面 题目描述 所谓虫食算,就是原先的算式中有一部分被虫子啃掉了,需要我们根据剩下的数字来判定被啃掉的字母.来看一个简单的例子: 43#9865#045 + 8468#6633 4 ...
- P1092 虫食算 题解(搜索)
题目链接 P1092 虫食算 解题思路 好题啊!这个搜索好难写...... 大概是要考虑进位和考虑使用过某个数字这两个东西,但就很容易出错...... 首先这个从后往前搜比较好想,按照从后往前出现的顺 ...
- 洛谷 P1092 虫食算 Label:dfs
题目描述 所谓虫食算,就是原先的算式中有一部分被虫子啃掉了,需要我们根据剩下的数字来判定被啃掉的字母.来看一个简单的例子: 43#9865#045 +8468#6633 44445509678 其中# ...
- Luogu P1092 虫食算
题目描述 所谓虫食算,就是原先的算式中有一部分被虫子啃掉了,需要我们根据剩下的数字来判定被啃掉的字母.来看一个简单的例子: 43#9865#045 +8468#6633 44445509678 其中# ...
- [NOIP2004] 提高组 洛谷P1092 虫食算
题目描述 所谓虫食算,就是原先的算式中有一部分被虫子啃掉了,需要我们根据剩下的数字来判定被啃掉的字母.来看一个简单的例子: 43#9865#045 +8468#6633 44445509678 其中# ...
- 洛谷—— P1092 虫食算
https://www.luogu.org/problem/show?pid=1092 题目描述 所谓虫食算,就是原先的算式中有一部分被虫子啃掉了,需要我们根据剩下的数字来判定被啃掉的字母.来看一个简 ...
- 【搜索】$P1092$虫食算
题目链接 首先,我们只考虑加法的虫食算.这里的加法是N进制加法,算式中三个数都有N位,允许有前导的0. 其次,虫子把所有的数都啃光了,我们只知道哪些数字是相同的,我们将相同的数字用相同的字母表示,不同 ...
- P1092 虫食算(洛谷)
今天做了一道题,我之前吹牛的时候曾经说:“这个题我觉得深搜剪枝一下就可以了.”. 我觉得我之前说的没错“这个题深搜剪枝亿下,再加点玄学就可以了!” 题目描述 所谓虫食算,就是原先的算式中有一部分被虫子 ...
随机推荐
- 安利一波那个叫做 hutool 的通用工具类库
摘自3.1.1版本作者发布原话,当时看到有点说不上的情绪,为作者的坚持.热爱点个赞. 已经想不起来是怎样结识 Hutool 的,但 Hutool 伴随几个项目的推进,获得了同事一致好评. 没经过实践和 ...
- 如何阻止sql注入(pdo篇)
Use prepared statements and parameterized queries. These are SQL statements that are sent to and par ...
- StringDup(理论AC)
Problem Statement for StringDup Problem Statement Create a class called StringDup. Given a stri ...
- 使用ichartjs生成图表
官网:http://www.ichartjs.com/ ichartjs 是一款基于HTML5的图形库.使用纯javascript语言, 利用HTML5的canvas标签绘制各式图形. ichartj ...
- SQL基本查询_多表查询(实验三)
SQL基本查询_多表查询(实验三) 题目要求(一) 针对emp.dept两表完成如下查询,并验证查询结果的正确性 使用显式内连接查询所有员工的信息,显示其编号.姓名.薪水.入职日期及部门名称: 使用隐 ...
- Linux上MySQL的安装
a.检测是否安装了mysql rpm -qa | grep mysql b.卸载系统自带的mysql rpm -e --nodeps 卸载的包 rpm -e --nodeps mysql-libs- ...
- python模块导入的方法与区别
import .. #导入整个模块 from .. import .. #导入模块中的类.函数或者变量 from .. import * #导入模块中的所有公开成员 from .. import ...
- 《项目架构那点儿事》——快速构建Junit用例
[前 言]按照惯例,在实际项目中我往往会对自己编写的程序进行测试,当测试通过后才能将其用于实战中,当然,编写单元测试是不可避免的,可以直接清晰的检验出 我们程序的可靠性.可只执行性,从中发现问题从而得 ...
- maven项目导出依赖的Jar包以及项目本身以jar包形式导出详细教程
一.maven项目已jar包形式导出 1.首先右键项目,选择Export 2.选择好项目,设置导出路径和jar名字即可: 二.导出maven项目所依赖的所有jar包 1.右键项目,选择Export 2 ...
- middlewares in GCC
Our GCC is a project developed by React that makes it painless to create interactive UIs. Design sim ...