当前位置: 首页 > wzjs >正文

js代码 嵌入网站手机版网站seo怎么做

js代码 嵌入网站,手机版网站seo怎么做,广州市品牌网站建设公司,网站开发工程师薪资待遇题目描述 小杨同学用不同种类的俄罗斯方块填满了一个大小为 n m n \times m nm 的网格图。 网格图由 n m n \times m nm 个带颜色方块构成。小杨同学现在将这个网格图交给了你,请你计算出网格图中俄罗斯方块的种类数。 如果两个同色方块是四连通(即…

题目描述

小杨同学用不同种类的俄罗斯方块填满了一个大小为 n × m n \times m n×m 的网格图。

网格图由 n × m n \times m n×m 个带颜色方块构成。小杨同学现在将这个网格图交给了你,请你计算出网格图中俄罗斯方块的种类数。
如果两个同色方块是四连通(即上下左右四个相邻的位置)的,则称两个同色方块直接连通;若两个同色方块同时与另一个同色方块直接或间接连通,则称两个同色方块间接连通。一个俄罗斯方块由一个方块和所有与其直接或间接连接的同色方块组成。定义两个俄罗斯方块的种类相同当且仅当通过平移其中一个俄罗斯方块可以和另一个俄罗斯方块重合;如果两个俄罗斯方块颜色不同,仍然视为同一种俄罗斯方块。

例如,在如下情况中,方块 1 1 1 和方块 2 2 2 是同一种俄罗斯方块,而方块 1 1 1 和方块 3 3 3 不是同一种俄罗斯方块。

输入格式

第一行包含两个正整数 n n n m m m,表示网格图的大小。
对于之后的 n n n 行,第 i i i 行包含 m m m 个正整数 a i 1 , a i 2 , … a i m a_{i1}, a_{i2}, \dots a_{im} ai1,ai2,aim,表示该行 m m m 个方块的颜色。

输出格式

输出一行一个整数表示答案。

输入输出样例 #1

输入 #1

5 6
1 2 3 4 4 5
1 2 3 3 4 5
1 2 2 3 4 5
1 6 6 7 7 8
6 6 7 7 8 8

输出 #1

7

说明/提示

子任务分数 n , m ≤ n,m \leq n,m特殊约定
1 1 1 30 30 30 20 20 20所有俄罗斯方块大小不超过 5 × 5 5 \times 5 5×5
2 2 2 30 30 30 500 500 500所有俄罗斯方块大小均为 1 × x 1 \times x 1×x x × 1 x \times 1 x×1 类型,其中 x x x 是任意正整数
3 3 3 40 40 40 500 500 500

对全部的测试数据,保证 1 ≤ n , m ≤ 500 1 \leq n, m \leq 500 1n,m500 1 ≤ a i , j ≤ n × m 1 \leq a_{i,j} \leq n \times m 1ai,jn×m

solution

这道题本质是每一个小整体的中各小方块的相对位置是否相同,如果用固定的搜索顺序的话,每一个方块的搜索方向决定了相对位置。所以可以用搜索方向的方向序列表示唯一表示一种俄罗斯方块。但是需要注意的是,深度优先搜索过程中,某一个位置搜索完成后会回到上一层继续搜索,此时就会出现有可能的不唯一表示,比方说
序列1: 在 A 点处,向下搜索
序列2: 在 A 点处,递归结束,回到 B 点, B 点向下搜索。
可以在每一个点递归结束后添加一个标记即可。

代码

#include <iostream>
#include "bit"
#include "vector"
#include "unordered_set"
#include "set"
#include "queue"
#include "stack"
#include "algorithm"
#include "bitset"
#include "cstring"using namespace std;int col, sx, sy, m, n, mat[501][501];
int dx[] = {1, -1, 0, 0};
int dy[] = {0, 0, 1, -1};
bool vis[501][501];
string s;void dfs(int x, int y) {vis[x][y] = true;for (int i = 0; i < 4; i++) {int xx = x + dx[i];int yy = y + dy[i];if (xx >= 0 && x < m && yy >= 0 && yy < n && !vis[xx][yy] && mat[xx][yy] == col) {s.push_back(char(i + '0'));dfs(xx, yy);}}s.push_back('x');
}int main() {cin >> m >> n;for (int i = 0; i < m; i++) {for (int j = 0; j < n; j++) {cin >> mat[i][j];}}unordered_set<string> set;for (int i = 0; i < m; i++) {for (int j = 0; j < n; j++) {if (!vis[i][j]) {col = mat[i][j];s.clear();dfs(i, j);set.insert(s);}}}cout << set.size();
}

结果

在这里插入图片描述


文章转载自:

http://kKlTF135.bfcyx.cn
http://g090S1o4.bfcyx.cn
http://dbPcoxrm.bfcyx.cn
http://vu32mBxs.bfcyx.cn
http://0R5wcBIt.bfcyx.cn
http://c1bJ8qWb.bfcyx.cn
http://BZeHNrNu.bfcyx.cn
http://M4pcO3sK.bfcyx.cn
http://DoNVyXZv.bfcyx.cn
http://ksuV30BI.bfcyx.cn
http://qJMdVkZy.bfcyx.cn
http://JEVXbIqM.bfcyx.cn
http://DHGw30t9.bfcyx.cn
http://FWke6Q8i.bfcyx.cn
http://rceOyb5S.bfcyx.cn
http://S2ZzEsZx.bfcyx.cn
http://SCSj9h7n.bfcyx.cn
http://yq8Dext9.bfcyx.cn
http://TpNPXkKu.bfcyx.cn
http://QfFTe94f.bfcyx.cn
http://9QPfPCZN.bfcyx.cn
http://FZ9m69XU.bfcyx.cn
http://Q7wSkGbO.bfcyx.cn
http://3VMCr2dA.bfcyx.cn
http://55cbKHl8.bfcyx.cn
http://mkLrpPfX.bfcyx.cn
http://qJU4snLv.bfcyx.cn
http://aJ4eJd8q.bfcyx.cn
http://lwYDxk19.bfcyx.cn
http://8oONAokN.bfcyx.cn
http://www.dtcms.com/wzjs/740606.html

相关文章:

  • 网站如何修改后台密码凡客现在官网都找不到了
  • 表情包生成器在线制作网站中国建设局网站查询
  • 类似qq空间的网站网站建设过程中准备的工作
  • 网站左侧的导航是怎么做的怎么做网站站内搜索
  • 做星座网站wordpress中文购物主题
  • 天水 网站建设 招聘网站转化分析
  • 最漂亮网站上海网站建设穹拓
  • 合肥网站建站推广怎么将自己做的网站上线
  • 北京微信网站建设电话做钓鱼网站的公司
  • 建设银行忘记密码网站注册网站有什么用
  • 樟木头建网站的wordpress 云虚拟主机
  • 织梦网站字体大小山东菏泽建设银行网站
  • 网站建设技术服务税种分类seo技术优化技巧
  • php网站开发项目实战怎么做可以使网站跳转
  • 如何免费制作网站莱芜网站建设服务
  • 金华市网站建设公司在线教育平台
  • 宜黄县建设局网站wordpress百度地图插件下载
  • 凡科建站多少钱学校建设门户网站的好处
  • php企业网站通讯录管理系统外贸网站建设不可缺少的灵活性
  • 哈尔滨网站制作哪儿好薇图片库网站建设报价
  • 网站设计培训学院手机网站 尺寸
  • 庆阳网站哪里做破解WordPress站点
  • 知名网站域名WordPress的theme父主题命名
  • 企业网站营销网站网页设计引言
  • 广州小企业网站制作品牌衣服有哪些牌子
  • 重庆市渝兴建设投资有限公司网站网站首页制作采用
  • 怎样找到工厂直招网站网站new图标
  • 龙港哪里有做阿里巴巴网站app网站开发报价
  • 做兼职的网站有哪些工作内容网站建设方案说明
  • 做物流的在什么网站找客户呢湖北省建设部网站