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 虫食算(洛谷)
今天做了一道题,我之前吹牛的时候曾经说:“这个题我觉得深搜剪枝一下就可以了.”. 我觉得我之前说的没错“这个题深搜剪枝亿下,再加点玄学就可以了!” 题目描述 所谓虫食算,就是原先的算式中有一部分被虫子 ...
随机推荐
- LeetCode 64. Minimum Path Sum(最小和的路径)
Given a m x n grid filled with non-negative numbers, find a path from top left to bottom right which ...
- ios 中的 GCD
摘自:http://www.cocoachina.com/swift/20150129/11057.html libdispatch是Apple所提供的在IOS和OS X上进行并发编程的库,而GCD正 ...
- 异步API
整合到一起,作为参考: //2 5 3 4 1 //2 5 3 1 4 var img = new Image(); img.src = '.'; img.onerror = function() { ...
- Warning: connect.static is not a function
grunt-contrib-connect从0.11.x版本开始不支持connect.static和connect.directory 你应该安装serve-static(加载静态文件)和serve- ...
- 一个基于EntityFramework Core的简单数据库访问层,适用于轻量级数据库业务
这个访问层的代码实际上是园子里某个前辈的,本人只是觉得好使,记录了下来. 本访问层需要通过Nuget安装EntityFramework Core,不过个人认为EF 6同样可以使用. 搭配数据库,最好是 ...
- IIC接口下的24C02 驱动分析
本节来学习IIC接口下的24C02 驱动分析,本节学完后,再来学习Linux下如何使用IIC操作24C02 1.I2C通信介绍 它是由数据线SDA和时钟SCL构成的串行总线,可发送和接收数据,是一个多 ...
- CDN 机制
CDN的全称Content Delivery Network,(缩写:CDN)即内容分发网络. CDN是一个经策略性部署的整体系统,从技术上全面解决由于网络带宽小.用户访问量大.网点分布不均而产生的用 ...
- DOM Exception error
INDEX_SIZE_ERR code 1 索引是负值,或者超过了索引值 DOMSTRING_SIZE_ERR code 2 ...
- Cocoapods使用过程中遇到的问题
前言:记录一些在CocoaPods使用过程中遇到的问题,本地环境:Xcode9.0 发现有的时候在执行pod init的时候不能正常地创建出来pod File文件,显示的错误如下: ――― MARKD ...
- linux分析日志的一些常用方法
head -n 2016_05_23_access_log |grep "/859" 显示前10000行中包含 /859 的记录 增加 |wc -l 则改为输出记录数 cat 2 ...