AOJ894 种花【图的搜索+回溯】

2023-11-02 10:08
文章标签 搜索 回溯 种花 aoj894

本文主要是介绍AOJ894 种花【图的搜索+回溯】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题面:

花老师有一个农场,农场的花一共有 4 种颜色, 花老师不喜欢老旧的东西,所以,她希望每天种花的方案都不一样。特别地,她也觉得两种一样颜色的花种在相邻的位置会很无聊。现在,她想知道,一共有多少种花的方案。这里要注意的是,农场的种花的位置是不规则的。因此我们给出一对一对的相邻的位置的关系。

Input
第一行两个数 N 和 M,表示种花的位置的个数和相邻的位置的对数
接下来 M 行,每行一组数 A, B 表示 A, B 相邻

Output
一个数表示染色方法数

Sample Input
5 4
1 2
1 3
1 4
1 5

Sample Output
324
Hint
N<=10,M<=50

大致思路:

比赛一开始将模型建错,导致WA了整场。
之后才知道这个题的解法是把每一种可能的情况都试出来,并且对于数据很大的情况下没有优化的方法。
整个算法执行的过程类似于DFS,先给一个点随便选一个颜色,然后从这个点相邻的点分别染色,染色的过程中保证合法。若所有可能情况都试过且都不合法,则回溯到上一个点。

代码:

#include<bits/stdc++.h>
using namespace std;
const int maxn=15;
int n,m,mp[maxn][maxn],color[maxn];
bool isame(int k)//判断染色是否合法
{for(int i=1;i<=n;++i)if(mp[i][k]==1&&color[i]==color[k])return false;return true;
}
int gcolor()
{memset(color,0,sizeof(color));int cnt=0,k=1;while(k>=1)//当k<0的时候就代表所有情况都已经尝试过,因为已经在第一个点的时候执行了回溯{color[k]++;//试颜色while(color[k]<=4)//保证染色的颜色合法{if(isame(k))break;color[k]++;}if(k==n&&color[k]<=4)//所有点都染好色cnt++;else if(k<n&&color[k]<=4)//前k个点已经染好色,继续染下一个点k++;else{//可能的情况都不存在,回溯到上一个点color[k]=0;k--;}}return cnt;
}
int main()
{ios::sync_with_stdio(false);//freopen("in.txt","r",stdin);int a,b;memset(mp,0,sizeof(mp));cin>>n>>m;for(int i=0;i<m;++i){cin>>a>>b;mp[b][a]=mp[a][b]=1;//建图}cout<<gcolor()<<endl;return 0;
}

这篇关于AOJ894 种花【图的搜索+回溯】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/329862

相关文章

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

hdu1240、hdu1253(三维搜索题)

1、从后往前输入,(x,y,z); 2、从下往上输入,(y , z, x); 3、从左往右输入,(z,x,y); hdu1240代码如下: #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#inc

hdu 4517 floyd+记忆化搜索

题意: 有n(100)个景点,m(1000)条路,时间限制为t(300),起点s,终点e。 访问每个景点需要时间cost_i,每个景点的访问价值为value_i。 点与点之间行走需要花费的时间为g[ i ] [ j ] 。注意点间可能有多条边。 走到一个点时可以选择访问或者不访问,并且当前点的访问价值应该严格大于前一个访问的点。 现在求,从起点出发,到达终点,在时间限制内,能得到的最大

AI基础 L9 Local Search II 局部搜索

Local Beam search 对于当前的所有k个状态,生成它们的所有可能后继状态。 检查生成的后继状态中是否有任何状态是解决方案。 如果所有后继状态都不是解决方案,则从所有后继状态中选择k个最佳状态。 当达到预设的迭代次数或满足某个终止条件时,算法停止。 — Choose k successors randomly, biased towards good ones — Close

hdu4277搜索

给你n个有长度的线段,问如果用上所有的线段来拼1个三角形,最多能拼出多少种不同的? import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;

回溯——9.全排列

力扣题目链接 给定一个 没有重复 数字的序列,返回其所有可能的全排列。 示例: 输入: [1,2,3]输出: [ [1,2,3], [1,3,2], [2,1,3], [2,3,1], [3,1,2], [3,2,1] ] 解题思路 问题建模:题目要求给出一个数组的所有排列组合,属于典型的全排列问题,这可以用回溯法来解决。回溯法通过递归的方式,依次将数组中的每个元素放入排列中,直到生成

浙大数据结构:04-树7 二叉搜索树的操作集

这道题答案都在PPT上,所以先学会再写的话并不难。 1、BinTree Insert( BinTree BST, ElementType X ) 递归实现,小就进左子树,大就进右子树。 为空就新建结点插入。 BinTree Insert( BinTree BST, ElementType X ){if(!BST){BST=(BinTree)malloc(sizeof(struct TNo

【python计算机视觉编程——7.图像搜索】

python计算机视觉编程——7.图像搜索 7.图像搜索7.1 基于内容的图像检索(CBIR)从文本挖掘中获取灵感——矢量空间模型(BOW表示模型)7.2 视觉单词**思想****特征提取**: 创建词汇7.3 图像索引7.3.1 建立数据库7.3.2 添加图像 7.4 在数据库中搜索图像7.4.1 利用索引获取获选图像7.4.2 用一幅图像进行查询7.4.3 确定对比基准并绘制结果 7.

记忆化搜索【下】

375. 猜数字大小II 题目分析 题目链接:375. 猜数字大小 II - 力扣(LeetCode) 题目比较长,大致意思就是给一个数,比如说10,定的数字是7,让我们在[1, 10]这个区间猜。 如果猜大或猜小都会说明是大了还是小了,此外,我们还需要支付猜错数字对应的现金。 现在就是让我们定制一个猜测策略,确保准备最少的钱能猜对 如果采用二分查找,只能确保最小次数,题目要求的

风控系统之指标回溯,历史数据重跑

个人博客:无奈何杨(wnhyang) 个人语雀:wnhyang 共享语雀:在线知识共享 Github:wnhyang - Overview 回顾 默认你已经看过之前那篇风控系统指标计算/特征提取分析与实现01,Redis、Zset、模版方法。 其中已经介绍了如何利用redis的zset结构完成指标计算,为了方便这篇文章的介绍,还是在正式开始本篇之前回顾一下。 时间窗口 zset