题目背景

考古学家发现了一块布,布上做有针线活,叫做“十字绣”,即交替地在布的两面穿线。

题目描述

布是一个n*m的网格,线只能在网格的顶点处才能从布的一面穿到另一面。每一段线都覆盖一个单位网格的两条对角线之一,而在绣的过程中,一针中连续的两段线必须分处布的两面。给出布两面的图案(实线代表该处有线,虚线代表背面有线),问最少需要几针才能绣出来?一针是指针不离开布的一次绣花过程。

输入输出格式

输入格式:

第1行两个数N和M(1<=N,M<=200)。

接下来N行每行M个数描述正面。

再接下来N行每行M个数描述反面。

每个格子用.(表示空),/(表示从右上角连到左下角),\(表示从左上角连到右下角)和X(表示连两条对角线)表示

输出格式:

一个数,最少要用的针数。

输入输出样例

输入样例#1:

  1. 4 5
  2. .....
  3. .\...
  4. ..\..
  5. .....
  6. .....
  7. ....\
  8. .\X..
  9. .....
输出样例#1:

  1. 4
    思路:然而我并不会(⊙o⊙)…可能是并查集吧!
  1. #include<iostream>
  2. #include<cstdio>
  3. #include<algorithm>
  4. #include<cstring>
  5. using namespace std;
  6. int n,m,num,sum,ans;
  7. int map[][];
  8. char s[][][];
  9. int b[],c[];
  10. int fa[],val[],vis[];
  11. int find(int x){
  12. if(fa[x]==x) return x;
  13. else return fa[x]=find(fa[x]);
  14. }
  15. int main(){
  16. scanf("%d%d",&n,&m);
  17. for(int i=;i<=n;i++)
  18. scanf("%s",s[][i]);
  19. for(int i=;i<=n;i++)
  20. scanf("%s",s[][i]);
  21. for(int k=;k<=;k++)
  22. for(int i=;i<=n;i++)
  23. for(int j=;j<m;j++){
  24. if(s[k][i][j]=='/'||s[k][i][j]=='X'){
  25. if(map[j+][i]==){
  26. num++;
  27. fa[num]=num;
  28. map[j+][i]=num;
  29. }
  30. if(map[j+][i+]==){
  31. num++;
  32. fa[num]=num;
  33. map[j+][i+]=num;
  34. }
  35. val[map[j+][i]]+=*k-;
  36. val[map[j+][i+]]+=*k-;
  37. int dx=find(map[j+][i]);
  38. int dy=find(map[j+][i+]);
  39. if(dx!=dy) fa[dy]=dx;
  40. }
  41. if(s[k][i][j]==||s[k][i][j]=='X'){
  42. if(map[j+][i]==){
  43. num++;
  44. fa[num]=num;
  45. map[j+][i]=num;
  46. }
  47. if(map[j+][i+]==){
  48. num++;
  49. fa[num]=num;
  50. map[j+][i+]=num;
  51. }
  52. val[map[j+][i]]+=*k-;
  53. val[map[j+][i+]]+=*k-;
  54. int dx=find(map[j+][i]);
  55. int dy=find(map[j+][i+]);
  56. if(dx!=dy) fa[dy]=dx;
  57. }
  58. }
  59. for(int i=;i<=num;i++){
  60. int dx=find(i);
  61. if(vis[dx]==){
  62. sum++;
  63. c[sum]=dx;
  64. vis[dx]=;
  65. }
  66. b[dx]=b[dx]+abs(val[i]);
  67. }
  68. for(int i=;i<=sum;i++){
  69. if(b[c[i]]==) b[c[i]]=;
  70. ans=ans+(b[c[i]]+)/;
  71. }
  72. cout<<ans;
  73. }
  1.  

洛谷 P1524 十字绣的更多相关文章

  1. 洛谷1640 bzoj1854游戏 匈牙利就是又短又快

    bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...

  2. 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.

    没有上司的舞会  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond       题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...

  3. 洛谷P1108 低价购买[DP | LIS方案数]

    题目描述 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:“低价购买:再低价购买”.每次你购买一支股票,你必须用低于你上次购买它的价格购买它 ...

  4. 洛谷 P2701 [USACO5.3]巨大的牛棚Big Barn Label:二维数组前缀和 你够了 这次我用DP

    题目背景 (USACO 5.3.4) 题目描述 农夫约翰想要在他的正方形农场上建造一座正方形大牛棚.他讨厌在他的农场中砍树,想找一个能够让他在空旷无树的地方修建牛棚的地方.我们假定,他的农场划分成 N ...

  5. 洛谷P1710 地铁涨价

    P1710 地铁涨价 51通过 339提交 题目提供者洛谷OnlineJudge 标签O2优化云端评测2 难度提高+/省选- 提交  讨论  题解 最新讨论 求教:为什么只有40分 数组大小一定要开够 ...

  6. 洛谷P1371 NOI元丹

    P1371 NOI元丹 71通过 394提交 题目提供者洛谷OnlineJudge 标签云端评测 难度普及/提高- 提交  讨论  题解 最新讨论 我觉得不需要讨论O long long 不够 没有取 ...

  7. 洛谷P1538迎春舞会之数字舞蹈

    题目背景 HNSDFZ的同学们为了庆祝春节,准备排练一场舞会. 题目描述 在越来越讲究合作的时代,人们注意的更多的不是个人物的舞姿,而是集体的排列. 为了配合每年的倒计时,同学们决定排出——“数字舞蹈 ...

  8. 洛谷八月月赛Round1凄惨记

    个人背景: 上午9:30放学,然后因为学校举办读书工程跟同学去书城选书,中午回来开始打比赛,下午又回老家,中间抽出一点时间调代码,回家已经8:50了 也许是7月月赛时“连蒙带骗”AK的太幸运然而因同学 ...

  9. 洛谷 P1379 八数码难题 Label:判重&&bfs

    特别声明:紫书上抄来的代码,详见P198 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给 ...

随机推荐

  1. CORS与JSONP的区别

    CORS与JSONP: a. JSONP只能实现GET请求,而CORS支持所有类型的HTTP请求. b. 使用CORS,开发者可以使用普通的XMLHttpRequest发起请求和获得数据,比起JSON ...

  2. JS 一个简单的隔行变色函数

    //输入要隔行变色的标签名 function setbgColor(tr){ var tr = document.getElementsByTagName("tr"); for(v ...

  3. 加密中加salt的意思

    所谓加Salt,就是加点“佐料”.当用户首次提供密码时(通常是注册时),由系统自动往这个密码里加一些“Salt值”,这个值是由系统随机生成的,并且只有系统知道.然后再散列.而当用户登录时,系统为用户提 ...

  4. Maven学习总结(25)——Eclipse Maven Update 时JDK版本变更问题

    1.新建一个Maven项目JDK版本和系统版本不对应, 2.右键Maven项目->Maven->Update ProjectJDK版本改变了, 3.操作系统的JDK重装了新的版本,这是引起 ...

  5. java源码之HashMap和HashTable的异同

    代码版本 JDK每一版本都在改进.本文讨论的HashMap和HashTable基于JDK 1.7.0_67 1. 时间 HashTable产生于JDK 1.1,而HashMap产生于JDK 1.2.从 ...

  6. ASP.NET-Active Direcotry编程示例

    查找指定的AD帐号 using (DirectoryEntry de = new DirectoryEntry("LDAP://RootDSE")) { string DCName ...

  7. 四旋翼飞行器Quadrotor飞控之 PID调节(參考APM程序)

    做四轴也有一段时间了.近期一直在做PID方面的工作. 如今四轴基本能够实现室内比較稳定的飞行,操控手感也能够接受.稍后上试飞视频.在此把一些PID方面的经验总结总结和大家分享一下. 首先介绍一下大概的 ...

  8. Struts2学习(四)利用ajax异步上传

    上一篇说到怎样在struts2中进行上传下载.我们使用了struts的标签通过表单提交的方式,但大家知道表单提交会造成页面总体的刷新,这样的方式很不友好,那我们今天就来说说怎样结合ajax方式进行异步 ...

  9. LeetCode_Maximum Depth of Binary Tree

    一.题目 Maximum Depth of Binary Tree My Submissions Given a binary tree, find its maximum depth. The ma ...

  10. 在Visual Studio Code中使用C#以及.net core

    Working with C# Using .NET Core in Visual Studio Code Note: VS Code does not support debugging appli ...