1、 单词接龙

https://www.luogu.org/problemnew/show/P1019

题目描述

单词接龙是一个与我们经常玩的成语接龙相类似的游戏,现在我们已知一组单词,且给定一个开头的字母,要求出以这个字母开头的最长的“龙”(每个单词都最多在“龙”中出现两次),在两个单词相连时,其重合部分合为一部分,例如 beastbeast和astonishastonish,如果接成一条龙则变为beastonishbeastonish,另外相邻的两部分不能存在包含关系,例如atat 和 atideatide 间不能相连。

输入输出格式

输入格式:

输入的第一行为一个单独的整数nn (n \le 20n≤20)表示单词数,以下nn 行每行有一个单词,输入的最后一行为一个单个字符,表示“龙”开头的字母。你可以假定以此字母开头的“龙”一定存在.

输出格式:

只需输出以此字母开头的最长的“龙”的长度。

输入输出样例

输入样例#1:

5
at
touch
cheat
choose
tact
a
输出样例#1:

23

核心函数:

计算两个字符串的尾首公共部分长度,不存在返回0

int splice(string s1, string s2) {
    , j = ;
    string help1, help2;
     && j < s2.length() - ) {
        help1.insert(, , s1[i]);
        help2.append(, s2[j]);
        ) return help1.length();
        i--; j++;
    }
    ;
}

完整代码:

#include <iostream>
#include <string>
#include <algorithm>
#include <vector>
#include <map>
using namespace std;

;
vector<string>v;
];

int splice(string s1, string s2) {
    , j = ;
    string help1, help2;
     && j < s2.length() - ) {
        help1.insert(, , s1[i]);
        help2.append(, s2[j]);
        ) return help1.length();
        i--; j++;
    }
    ;
}

void DFS(string help) {
    bool flag = true;//标记,当本层递归没有一个字符串可以往后加时,退出

    ; i < v.size(); i++) {
        int cnt = splice(help, v[i]);
         && cnt != ) {
            flag = false;
            use[i]++;
            string t = help;
            DFS(help.append(v[i].substr(cnt)));
            help = t;
            use[i]--;
        }
    }
    if (flag) {
        if (help.length() > maxcnt)maxcnt = help.length();
        return;
    }
}

int main() {
    int n;
    string s;
    cin >> n;
    while (n--) {
        cin >> s;
        v.push_back(s);
    }
    char head;
    cin >> head;
    ; i < v.size(); i++) {
        ] == head) {
            //不确定是否只有一个龙头
            use[i]++;
            DFS(v[i]);
            use[i]--;
        }
    }
    cout << maxcnt << endl;
    ;
}

2、单词方阵

https://www.luogu.org/problemnew/show/P1101

给一个n×n的字母方阵,内可能蕴含多个“yizhong”单词。单词在方阵中是沿着同一方向连续摆放的。摆放可沿着 8 个方向的任一方向,同一单词摆放时不再改变方向,单词与单词之间可以交叉,因此有可能共用字母。输出时,将不是单词的字母用*代替,以突出显示单词。例如:

输入:
    8                     输出:
    qyizhong              *yizhong
    gydthkjy              gy******
    nwidghji              n*i*****
    orbzsfgz              o**z****
    hhgrhwth              h***h***
    zzzzzozo              z****o**
    iwdfrgng              i*****n*
    yyyygggg              y******g

每碰到一个'y',八向搜索。如果满足该方向的条件就递归,否则结束递归。用数组保存递归路径。

#include <iostream>
#include <string>
#include <algorithm>
#include <vector>
#include <map>
using namespace std;

string standard = "yizhong";
int n;
][];
//上,下,左,右,左上,左下,右上,右下
//每个方向x,y的增量
][] = { {-,},{,},{,-}, {,},{-,-},{,-},{-,},{,} };
][];
//记录下路径
][];
void DFS(int x, int y, int k,int dir) {
     || x == n || y <  || y == n)return;
    if (k == standard.length()) {
        ; i < ; i++) {
            res[path[i][]][path[i][]] = standard[i];
        }
        return;
    }

    ]][y + direction[dir][]] == standard[k]) {
        path[k][] = x + direction[dir][];
        path[k][] = y + direction[dir][];
        DFS(x + direction[dir][], y + direction[dir][], k + , dir);
    }
}

int main() {
    cin >> n;
    ; i < n; i++) {
        ; j < n; j++) {
            cin >> m[i][j];
        }
    }

    ; x < n; x++) {
        ; y < n; y++) {
            if (m[x][y] == 'y') {
                ; i < ; i++) {
                    path[][] = x;
                    path[][] = y;
                    DFS(x, y, , i);
                }
            }
        }
    }
    ; x < n; x++) {
        ; y < n; y++) {
            )
                cout << res[x][y];
            else
                cout << '*';
        }
        cout << endl;
    }

    ;
}

3、迷宫

https://www.luogu.org/problemnew/show/P1605

#include <iostream>
using namespace std;

//上下左右
][] = { {-,},{,},{,-},{,} };

][];

int N, M, T, cnt;
int SX, SY, EX, EY;

void DFS(int x, int y) {
     || x>N || y <  || y > M) return;
    if (x == EX && y == EY) {
        cnt++;
        return;
    }
    ; i < ; i++) {
        ]][y + direction[i][]] != ) {
            m[x + direction[i][]][y + direction[i][]] = ;
            DFS(x + direction[i][], y + direction[i][]);
            m[x + direction[i][]][y + direction[i][]] = ;
        }
    }
}
int main() {
    cin >> N >> M >> T;
    cin >> SX >> SY >> EX >> EY;
    ; i < T; i++) {
        int x,y;
        cin >> x >> y;
        m[x][y] = ;
    }
    m[SX][SY] = ;

    DFS(SX, SY);
    cout << cnt << endl;
    ;
}

P1162 填涂颜色

  取巧一点的做法,把外面的0变成-1,就和里面的区分出来,但是外面的0一不一定是连通的,可以把所有边界走完一遍,所有是0的都进行DFS函数一次。

但是,有简单的办法,数组多开一圈,这一圈置0,那么边界0就一定是连通的了,一次DFS就行了。

#include <iostream>
#include <stdio.h>
using namespace std;
][];
int n;
][] = { {-,},{,},{,-},{,} };

void DFS(int x, int y, int sign) {
     || y <  || x > n +  || y > n + ) return;
    ; i < ; i++) {
        ], toy = y + dir[i][];
        if (m[tox][toy] == sign) {
                m[tox][toy] = -;
            DFS(tox, toy, sign);
        }
    }
}

int main() {
    cin >> n;
    ; i <= n; i++) {
        ; j <= n; j++) {
            cin >> m[i][j];
        }
    }

    DFS(, , );
    ; i <= n; i++) {
        ; j <= n; j++) {
            )cout <<  << ' ';
            )cout <<  << ' ';
             << ' ';
        }
        cout << endl;
    }

    ;
}

随手练——DFS小练的更多相关文章

  1. dfs小练 【dfs】

    1.前n个自然数的所有排列: #include <iostream> #include <cstdio> #include <cstring> using name ...

  2. js 计时器小练-20160601

    今天要做一个计时器小练,所以我就做了练习,代码如下. // 初始化时间,以及定义全局量去接收计时器 var timer = 0; var t; var h, min, sec, millisec; / ...

  3. 【Python】【辅助程序】练手小程序:记录外网动态IP地址

    练手小程序 程序作用:对IP实时记录: 1.定时获取外网IP,存储在本地文件中: 编写思路: 1)收集获取外网的API接口       http://bbs.125.la/thread-1383897 ...

  4. 【Python精华】100个Python练手小程序

    100个Python练手小程序,学习python的很好的资料,覆盖了python中的每一部分,可以边学习边练习,更容易掌握python. [程序1] 题目:有1.2.3.4个数字,能组成多少个互不相同 ...

  5. 整理了适合新手的20个Python练手小程序

    100个Python练手小程序,学习python的很好的资料,覆盖了python中的每一部分,可以边学习边练习,更容易掌握python. 本文附带基础视频教程:私信回复[基础]就可以获取的 [程序1] ...

  6. 算法小练#1 - Dany Yang

    开始记录每周做过的算法题,这是第一周,新的开始 1021. 删除最外层的括号 题目要求如下: 有效括号字符串为空 ("")."(" + A + ")& ...

  7. 初始Spring MVC——练手小项目

    初始Spring MVC 前几天开始了我的spring学习之旅,由于之前使用过MVC模式来做项目,所以我先下手的是 Spring MVC,做个练手项目,非常简单 项目介绍: 用户输入信息 -> ...

  8. java算法题每日一练01,java入门简单算法题小练

    1.给数组做反序 public class Ak01 { public static void main(String[] args) { int[] a = new int[]{22,48,41,2 ...

  9. 8.1搜索专练DFS和BFS

    这是第一次全部做出来的依次练习了,有一些都是做过两遍了的,但是还是错了几回,更多时候我还是应该多注意下细节,就好像章爷笑我 的一样,像什么vis[]标记没清0,什么格式错误,还有什么题目没看清,还是的 ...

随机推荐

  1. [c#] Html Agility Pack 解析HTML

    摘要 在开发过程中,很有可能会遇到这样的情况,服务端返回的是html的内容,但需要在客户端显示纯文本内容,这时候就需要解析这些html,拿到里面的纯文本.达到这样的目的可以有很多途径,比如自己写正则表 ...

  2. NavicatForOracle无法连接数据库,报错ORA-28547

    因为换了新项目,要用到oracle数据库,但是用Navicat连接oracle不像连接MySql那样简单,连接的时候总是报ORA-28547,最后搜了一下解决方案发现是install client没有 ...

  3. leetcode树专题894.897,919,951

    满二叉树是一类二叉树,其中每个结点恰好有 0 或 2 个子结点. 返回包含 N 个结点的所有可能满二叉树的列表. 答案的每个元素都是一个可能树的根结点. 答案中每个树的每个结点都必须有 node.va ...

  4. mysql报错1105 -without an explicit primary key with pxc_strict_mode = ENFORCING or MASTER

    mysql报错1105 -without an explicit primary key with pxc_strict_mode = ENFORCING or MASTER. 在本地正常,但是在服务 ...

  5. Median(vector+二分)

    Median Time Limit: 5 Seconds Memory Limit: 65536 KB The median of m numbers is after sorting them in ...

  6. 数据库概念:码 键 Key & 范式 Normal Form

    参考资料 数据库管理系统原理与设计(Database Mangement System 3rd) 百度 wiki 术语对照 码 = 键 = Key 码约束 = Key Constraints 码约束 ...

  7. PHP实现大转盘抽奖算法

    流程: 1.拼装奖项数组,2.计算概率,3.返回中奖情况 代码如下:中奖概率 ' v ' 可以在后台设置,传到此方法中,注意传整数 function get_gift(){ //拼装奖项数组 // 奖 ...

  8. Leaflet.draw 无法编辑multipolygon类型多边形 解决方法

    问题说明 在做面要素的编辑的时候,当对multiploygon类型的面要素进行编辑的时候,出现如下错误: TypeError: Cannot read property 'lat' of null 通 ...

  9. Loadrunner脚本优化-参数化之关联MySQL数据库获取数据

    脚本优化-参数化之关联MySQL数据库获取数据 by:授客 QQ:1033553122 测试环境: Loadrunner 11 Win7 64位 实操: 1.   安装MySQL ODBC驱动程序 O ...

  10. 单元测试(一)-NUnit基础

    单元测试作为提高代码和软件质量的有效途径,其重要性和益处自不必多说,虽然我没有实践过TDD之类,但坚信单元测试的积极作用.作为一种开发方法,单元测试早在上世纪70年代就已经在Smalltalk语言被运 ...