最小生成树问题:njupt-1418:清扫

2024-05-26 00:58

本文主要是介绍最小生成树问题:njupt-1418:清扫,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

清扫

时间限制(普通/Java) :  1000 MS/ 3000 MS          运行内存限制 : 65536 KByte
总提交 : 6            测试通过 : 5 

比赛描述

现在要打扫国王的牧圈。已经30年没打扫了。所以这次的计划是用河水来冲。
牧圈排成整齐的格子,每相邻的两个之间都有门。要想让水进去,就必须打开这些门。这不是件容易的事情。因为有些圈里土堆得很高。因此打开门就很费劲。为了使花的力气最小,总是把门推向土低的一边。你的任务是计算最少得费多少劲。我们用土的厚度来描述这个值。

 



输入

第一行是宽度w和高度h,其中3 <= w,h <= 40。以下h行数据,描述了土的高度,也就是我们所浪费体力的度量。数据的范围在1100之间。

输出

你得到的结果。所有的格子都必须进水。水是从左上角的格子进去的。

样例输入

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

样例输出

26

代码超时:

#include<stdio.h>
#include<stdlib.h>
int map[41][41];
int maxx,maxy;
int ans=0,ans0;
struct p 
{int x,y;
}pd[41*41];
int maxn=0;int min(int a,int b)
{if(a<b)return a;return b;
}
int getscore(int x,int y,int a,int b)
{int ans2=min(map[x][y],map[a][b]);return ans2;
}
int ifin(int x,int y)
{int i;int ans = 0;for(i=1;i<=maxn;i++){if(pd[i].x==x&&pd[i].y==y)ans=1;}return ans;
}int main()
{int i,j,k;int n;int x,y;int ansx,ansy;scanf("%d %d",&maxx,&maxy);for(j=1;j<=maxy;j++)for(i=1;i<=maxx;i++){scanf("%d",&map[i][j]);}n=maxx*maxy;maxn=1;pd[maxn].x=1;pd[maxn].y=1;while(maxn!=n){ans0=9999999;for(i=1;i<=maxn;i++){x = pd[i].x;y = pd[i].y;if(x>1&&ifin(x-1,y)==0){if(ans0>getscore(x,y,x-1,y)){ans0=getscore(x,y,x-1,y);ansx = x-1;ansy =y;}}if(x<maxx&&ifin(x+1,y)==0){if(ans0>getscore(x,y,x+1,y)){ans0=getscore(x,y,x+1,y);ansx = x+1;ansy =y;}}if(y>1&&ifin(x,y-1)==0){if(ans0>getscore(x,y,x,y-1)){ans0=getscore(x,y,x,y-1);ansx = x;ansy =y-1;}}if(y<maxy&&ifin(x,y+1)==0){if(ans0>getscore(x,y,x,y+1)){ans0=getscore(x,y,x,y+1);ansx = x;ansy =y+1;}}}maxn++;pd[maxn].x=ansx;pd[maxn].y=ansy;ans = ans + ans0;}printf("%d\n",ans);system("pause");return 0;
}


这篇关于最小生成树问题:njupt-1418:清扫的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java利用docx4j+Freemarker生成word文档

《Java利用docx4j+Freemarker生成word文档》这篇文章主要为大家详细介绍了Java如何利用docx4j+Freemarker生成word文档,文中的示例代码讲解详细,感兴趣的小伙伴... 目录技术方案maven依赖创建模板文件实现代码技术方案Java 1.8 + docx4j + Fr

SpringBoot首笔交易慢问题排查与优化方案

《SpringBoot首笔交易慢问题排查与优化方案》在我们的微服务项目中,遇到这样的问题:应用启动后,第一笔交易响应耗时高达4、5秒,而后续请求均能在毫秒级完成,这不仅触发监控告警,也极大影响了用户体... 目录问题背景排查步骤1. 日志分析2. 性能工具定位优化方案:提前预热各种资源1. Flowable

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

java中使用POI生成Excel并导出过程

《java中使用POI生成Excel并导出过程》:本文主要介绍java中使用POI生成Excel并导出过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录需求说明及实现方式需求完成通用代码版本1版本2结果展示type参数为atype参数为b总结注:本文章中代码均为

在java中如何将inputStream对象转换为File对象(不生成本地文件)

《在java中如何将inputStream对象转换为File对象(不生成本地文件)》:本文主要介绍在java中如何将inputStream对象转换为File对象(不生成本地文件),具有很好的参考价... 目录需求说明问题解决总结需求说明在后端中通过POI生成Excel文件流,将输出流(outputStre

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

MySQL新增字段后Java实体未更新的潜在问题与解决方案

《MySQL新增字段后Java实体未更新的潜在问题与解决方案》在Java+MySQL的开发中,我们通常使用ORM框架来映射数据库表与Java对象,但有时候,数据库表结构变更(如新增字段)后,开发人员可... 目录引言1. 问题背景:数据库与 Java 实体不同步1.1 常见场景1.2 示例代码2. 不同操作

如何解决mysql出现Incorrect string value for column ‘表项‘ at row 1错误问题

《如何解决mysql出现Incorrectstringvalueforcolumn‘表项‘atrow1错误问题》:本文主要介绍如何解决mysql出现Incorrectstringv... 目录mysql出现Incorrect string value for column ‘表项‘ at row 1错误报错