杭电 1045题 Fire Net

2024-05-29 19:18
文章标签 net 杭电 1045 fire

本文主要是介绍杭电 1045题 Fire Net,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接~~>

简单深度搜索,第一次做一次AC,第二次换了一种方法就找不出错误了!

search(x,y+1,t+1); s[x][y+1]='.';后面应该还有一个search(x,y+1,t);的调用;

代码(1):

#include<stdio.h>
int n,max=0;
char s[5][5];
void dfs(int x,int y,int q)
{void search(int x,int y,int q);int i,j;int f=0;for(i=x+1;i<n;i++)if(s[i][y]=='X')break;else if(s[i][y]=='Q'){f=1;break;}for(j=y+1;j<n;j++)if(s[x][j]=='X')break;else if(s[x][j]=='Q'){f=1;break;}for(i=x-1;i>=0;i--)if(s[i][y]=='X')break;else if(s[i][y]=='Q'){f=1;break;}for(j=y-1;j>=0;j--)if(s[x][j]=='X')break;else if(s[x][j]=='Q'){f=1;break;}if(f==0){s[x][y]='Q';q++;f=0;}if(q>max)max=q;search(x,y,q);s[x][y]='.';
}
void search(int x,int y,int q)
{int i,j;if(y==n-1){x=x+1;y=-1;}for(i=x;i<n;i++){    if(i!=x)y=-1;for(j=y+1;j<n;j++)if(s[i][j]=='.'){dfs(i,j,q);}}
}
int main()
{int i,j;while(scanf("%d",&n)!=EOF){max=0;if(n==0)break;for(i=0;i<n;i++)scanf("%s",s[i]);for(i=0;i<n;i++)for(j=0;j<n;j++)if(s[i][j]=='.'){dfs(i,j,0);}printf("%d\n",max);}return 0;
}


 

代码(2):

#include<stdio.h>
char s[5][5];
int max,n;
void search(int x,int y,int t)
{int i,flag=0;if(t>max)max=t;if(y==n){x++;y=0;}if(x==n)return ;if(s[x][y]=='X')flag=1;for(i=x+1;i<n;i++)if(s[i][y]=='A'){flag=1;break;}else if(s[i][y]=='X')break;for(i=x-1;i>=0;i--)if(s[i][y]=='A'){flag=1;break;}else if(s[i][y]=='X')break;for(i=y-1;i>=0;i--)if(s[x][i]=='A'){flag=1;break;}else if(s[x][i]=='X')break;for(i=y+1;i<n;i++)if(s[x][i]=='A'){flag=1;break;}else if(s[x][i]=='X')break;if(flag==0){s[x][y]='A';// printf("%d\n",t+1);search(x,y+1,t+1);s[x][y]='.';search(x,y+1,t);}elsesearch(x,y+1,t);
}
int main()
{int i,j;while(scanf("%d",&n)!=EOF){if(n==0)break;max=0;for(i=0;i<n;i++)scanf("%s",s[i]);for(i=0;i<n;i++)for(j=0;j<n;j++)if(s[i][j]=='.'){search(i,j,0);}printf("%d\n",max);}return 0;
}


 

优代码链接~>

这篇关于杭电 1045题 Fire Net的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

如何在Visual Studio中调试.NET源码

今天偶然在看别人代码时,发现在他的代码里使用了Any判断List<T>是否为空。 我一般的做法是先判断是否为null,再判断Count。 看了一下Count的源码如下: 1 [__DynamicallyInvokable]2 public int Count3 {4 [__DynamicallyInvokable]5 get

2、PF-Net点云补全

2、PF-Net 点云补全 PF-Net论文链接:PF-Net PF-Net (Point Fractal Network for 3D Point Cloud Completion)是一种专门为三维点云补全设计的深度学习模型。点云补全实际上和图片补全是一个逻辑,都是采用GAN模型的思想来进行补全,在图片补全中,将部分像素点删除并且标记,然后卷积特征提取预测、判别器判别,来训练模型,生成的像

.NET 自定义过滤器 - ActionFilterAttribute

这个代码片段定义了一个自定义的 ASP.NET Core 过滤器(GuardModelStateAttribute),用于在控制器动作执行之前验证模型状态(ModelState)。如果模型状态无效,则构造一个 ProblemDetails 对象来描述错误,并返回一个 BadRequest 响应。 代码片段: /// <summary>/// 验证 ModelState 是否有效/// </

.Net Mvc-导出PDF-思路方案

效果图: 导语:     在我们做项目的过程中,经常会遇到一些服务性的需求,感到特别困扰,明明实用的价值不高,但是还是得实现;     因此小客在这里整理一下自己导出PDF的一些思路,供大家参考。     网上有很多导出PDF运用到的插件,大家也可以看看其他插件的使用,学习学习; 提要:     这里我使用的是-iTextSharp,供大家参考参考,借鉴方案,完善思路,补充自己,一起学习

.net MVC 导出Word--思路详解

序言:          一般在项目的开发过程中,总会接收到一个个需求,其中将数据转换成Work来下载,是一个很常见的需求;          那么,我们改如何处理这种需求,并输出实现呢?          在做的过程中,去思考 1、第一步:首先确认,Work的存在位置,并创建字符输出路:             //在的项目中创建一个存储work的文件夹             string

asp.net 中GridView的使用方法

可以看看,学习学习 https://blog.csdn.net/zou15093087438/article/details/79637042

ASP.NET状态管理的总结

由于HTTP协议的无状态特性,导致在ASP.NET编程中,每个请求都会在服务端从头到执行一次管线过程, 对于ASP.NET页面来说,Page对象都会重新创建,所有控件以及内容都会重新生成, 因此,如果希望上一次的页面状态能够在后续页面中保留,则必需引入状态管理功能。   ASP.NET为了实现状态管理功能,提供了8种方法,可帮助我们在页面之间或者整个用户会话期间保留状态数据。 这些方法分为二类:

ASP.NET手动触发页面验证控件事件

开发环境:.NET Framework 3.5.1 sp1 参考文章: http://www.codeproject.com/KB/aspnet/JavascriptValidation.aspx http://msdn.microsoft.com/zh-cn/library/aa479045.aspx http://www.cnblogs.com/minsentinel/archive/

在VB.net中,如何把20240906转化成日期格式

==标题== vb.net中,如何把20240906转化成日期格式 ==正文== 在 VB.NET 中,将一个数字字符串(如 "20240906")转换为日期格式,你可以使用 `DateTime.Parse` 或 `DateTime.TryParse` 方法。这些方法可以将符合日期格式的字符串解析为 `DateTime` 对象。以下是如何将 "20240906" 这样的字符串转换为日期格式的示