题目传送: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 虫食算的更多相关文章

  1. 洛谷P1092 虫食算

    P1092 虫食算 题目描述 所谓虫食算,就是原先的算式中有一部分被虫子啃掉了,需要我们根据剩下的数字来判定被啃掉的字母.来看一个简单的例子: http://paste.ubuntu.com/2544 ...

  2. 【题解】 P1092虫食算

    [题解]P1092 虫食算 老题了,很经典. 用到了一些搜索套路. 可行性剪枝,劣者靠后,随机化,\(etc......\) 搜索设参也很有技巧,设一个\(adjustment\)参数可以很方便地在两 ...

  3. Luogu P1092 虫食算(枚举+剪枝)

    P1092 虫食算 题面 题目描述 所谓虫食算,就是原先的算式中有一部分被虫子啃掉了,需要我们根据剩下的数字来判定被啃掉的字母.来看一个简单的例子: 43#9865#045 + 8468#6633 4 ...

  4. P1092 虫食算 题解(搜索)

    题目链接 P1092 虫食算 解题思路 好题啊!这个搜索好难写...... 大概是要考虑进位和考虑使用过某个数字这两个东西,但就很容易出错...... 首先这个从后往前搜比较好想,按照从后往前出现的顺 ...

  5. 洛谷 P1092 虫食算 Label:dfs

    题目描述 所谓虫食算,就是原先的算式中有一部分被虫子啃掉了,需要我们根据剩下的数字来判定被啃掉的字母.来看一个简单的例子: 43#9865#045 +8468#6633 44445509678 其中# ...

  6. Luogu P1092 虫食算

    题目描述 所谓虫食算,就是原先的算式中有一部分被虫子啃掉了,需要我们根据剩下的数字来判定被啃掉的字母.来看一个简单的例子: 43#9865#045 +8468#6633 44445509678 其中# ...

  7. [NOIP2004] 提高组 洛谷P1092 虫食算

    题目描述 所谓虫食算,就是原先的算式中有一部分被虫子啃掉了,需要我们根据剩下的数字来判定被啃掉的字母.来看一个简单的例子: 43#9865#045 +8468#6633 44445509678 其中# ...

  8. 洛谷—— P1092 虫食算

    https://www.luogu.org/problem/show?pid=1092 题目描述 所谓虫食算,就是原先的算式中有一部分被虫子啃掉了,需要我们根据剩下的数字来判定被啃掉的字母.来看一个简 ...

  9. 【搜索】$P1092$虫食算

    题目链接 首先,我们只考虑加法的虫食算.这里的加法是N进制加法,算式中三个数都有N位,允许有前导的0. 其次,虫子把所有的数都啃光了,我们只知道哪些数字是相同的,我们将相同的数字用相同的字母表示,不同 ...

  10. P1092 虫食算(洛谷)

    今天做了一道题,我之前吹牛的时候曾经说:“这个题我觉得深搜剪枝一下就可以了.”. 我觉得我之前说的没错“这个题深搜剪枝亿下,再加点玄学就可以了!” 题目描述 所谓虫食算,就是原先的算式中有一部分被虫子 ...

随机推荐

  1. $(window).on("load",function(){} 和 $(document).ready(function() {}

    $(window).on("load",function(){ //页面属性,图片,内容完全加载完,执行 } $(document).ready(function() { 或者$( ...

  2. LeetCode 15. 3Sum(三数之和)

    Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0? Find all un ...

  3. Unity3D手机斗地主游戏开发实战(01)_发牌功能实现

    园子荒废多年,闲来无事,用Unity3D来尝试做一个简单的小游戏,一方面是对最近研究的Unity3D有点总结,一方面跟广大的园友相互学习和提高.话不多说,进入正题~ 一.创建项目 1.创建Unity2 ...

  4. 读书笔记-你不知道的JS上-对象

    好想要对象··· 函数的调用位置不同会造成this绑定对象不同.但是对象到底是什么,为什么要绑定他们呢?(可以可以,我也不太懂) 语法 对象声明有两个形式: 1.字面量 => var obj = ...

  5. 数据处理不等式:Data Processing Inequality

    我是在差分隐私下看到的,新解决方案的可用性肯定小于原有解决方案的可用性,也就是说信息的后续处理只会降低所拥有的信息量. 那么如果这么说的话为什么还要做特征工程呢,这是因为该不等式有一个巨大的前提就是数 ...

  6. Codeforces 376B. Coupons and Discounts

    B. Coupons and Discounts time limit per test 1 second memory limit per test 256 megabytes input stan ...

  7. Sqoop的安装部署

    在root的用户下 1):前提 安装JDK环境 2):前提 安装Hadoop和Hive客户端环境,如果需要导出到HBase则需要安装HBase客户端 3):下载sqoop : 命令: wget htt ...

  8. ④bootstrap列表使用基础案例

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. python3.0 模拟用户登录,三次错误锁定

    # -*- coding:utf-8 -*- #需求模拟用户登录,超过三次错误锁定不允许登陆     count = 0   #realname passwd Real_Username = &quo ...

  10. Chartist.js-同时画柱状图和折线图

    最近几天都在研究chartist,因为echarts生成的图是位图,导成PDF的时候不够清晰.而chartist是搜到的免费插件中呼声较高的,基于SVG. 今天主要是想举一些代码例子给大家,介绍下如何 ...