博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
csp 2014_9_4 最优配餐
阅读量:4215 次
发布时间:2019-05-26

本文共 1675 字,大约阅读时间需要 5 分钟。

注意 变量的范围 要取long类型

package csp2014_9_4;import java.util.Arrays;import java.util.LinkedList;import java.util.List;import java.util.Scanner;import org.w3c.dom.css.ViewCSS;public class Main {	long[][]map;	boolean [][]visit;	int n, m, k, d;	int [][]dir = {
{0,1},{0,-1},{1,0},{-1,0}}; long ans; LinkedList
que; public static void main(String[] args) { new Main().run(); } public void run() { Scanner in = new Scanner(System.in); while(in.hasNext()) { n = in.nextInt(); m = in.nextInt(); k = in.nextInt(); d = in.nextInt(); que = new LinkedList<>(); visit = new boolean[n+1][n+1]; map = new long[n+1][n+1]; for(int i = 0; i < m; i++ ) { int x = in.nextInt(); int y = in.nextInt(); que.offer(new Node(x, y, 0)); } for(int i = 0; i < k; i++ ) { int x = in.nextInt(); int y = in.nextInt(); long num = in.nextInt(); map[x][y] = num; } for(int i = 0; i < d; i++ ) { int x = in.nextInt(); int y = in.nextInt(); visit[x][y] = true; } ans = 0; bfs(); System.out.println(ans); } } public void bfs() { int cnt = 0; while(!que.isEmpty()) { Node node = que.poll(); for(int i = 0; i < 4; i++ ) { int xx = node.x + dir[i][0]; int yy = node.y + dir[i][1]; if(xx>0&&yy>0&&xx<=n&&yy<=n&&!visit[xx][yy]) { visit[xx][yy] = true; ans += (node.step+1)*map[xx][yy]; Node tmp = new Node(xx, yy, node.step+1); que.offer(tmp); } } } }}class Node{ int x, y; long mum; long step; public Node(int x, int y, long s) { step = s; this.x = x; this.y = y; } }

上面 可以在达到目标后提前终止

if(map[xx][yy] != 0) {						ans += (node.step+1)*map[xx][yy];						cnt++;						if(cnt == k)							return;					}

转载地址:http://blimi.baihongyu.com/

你可能感兴趣的文章
hdu 3460 Ancient Printer(trie tree)
查看>>
KMP求前缀函数(next数组)
查看>>
KMP
查看>>
poj 3863Business Center
查看>>
Android编译系统简要介绍和学习计划
查看>>
Android编译系统环境初始化过程分析
查看>>
user2eng 笔记
查看>>
DRM in Android
查看>>
ARC MRC 变换
查看>>
Swift cell的自适应高度
查看>>
【linux】.fuse_hiddenXXXX 文件是如何生成的?
查看>>
【LKM】整合多个LKM为1个
查看>>
【Windows C++】调用powershell上传指定目录下所有文件
查看>>
Java图形界面中单选按钮JRadioButton和按钮Button事件处理
查看>>
小练习 - 排序:冒泡、选择、快排
查看>>
SparkStreaming 如何保证消费Kafka的数据不丢失不重复
查看>>
Spark Shuffle及其调优
查看>>
数据仓库分层
查看>>
常见数据结构-TrieTree/线段树/TreeSet
查看>>
Hive数据倾斜
查看>>