一个旅游景点,如果被带火了的话,就被称为“网红点”。大家来网红点游玩,俗称“打卡”。在各个网红点打卡的快(省)乐(钱)方法称为“攻略”。你的任务就是从一大堆攻略中,找出那个能在每个网红点打卡仅一次、并且路上花费最少的攻略。

输入格式:
首先第一行给出两个正整数:网红点的个数 N(1<N≤200)和网红点之间通路的条数 M。随后 M 行,每行给出有通路的两个网红点、以及这条路上的旅行花费(为正整数),格式为“网红点1 网红点2 费用”,其中网红点从 1 到 N 编号;同时也给出你家到某些网红点的花费,格式相同,其中你家的编号固定为 0。
再下一行给出一个正整数 K,是待检验的攻略的数量。随后 K 行,每行给出一条待检攻略,格式为:nV1V2⋯V n其中 n(≤200) 是攻略中的网红点数,Vi
​是路径上的网红点编号。这里假设你从家里出发,从V1开始打卡,最后从 Vn
​回家。

输出格式:
在第一行输出满足要求的攻略的个数。

在第二行中,首先输出那个能在每个网红点打卡仅一次、并且路上花费最少的攻略的序号(从 1 开始),然后输出这个攻略的总路费,其间以一个空格分隔。如果这样的攻略不唯一,则输出序号最小的那个。

题目保证至少存在一个有效攻略,并且总路费不超过 10
9

输入样例:

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

输出样例:

3
5 11

样例说明:
第 2、3、4、6 条都不满足攻略的基本要求,即不能做到从家里出发,在每个网红点打卡仅一次,且能回到家里。所以满足条件的攻略有 3 条。
第 1 条攻略的总路费是:(0->5) 2 + (5->1) 2 + (1->4) 2 + (4->3) 2 + (3->6) 2 + (6->2) 2 + (2->0) 2 = 14;
第 5 条攻略的总路费同理可算得:1 + 1 + 1 + 2 + 3 + 1 + 2 = 11,是一条更省钱的攻略;
第 7 条攻略的总路费同理可算得:2 + 1 + 1 + 2 + 2 + 2 + 1 = 11,与第 5 条花费相同,但序号较大,所以不输出。

import java.util.*;
import java.io.*;class reader {static BufferedReader buf = new BufferedReader(new InputStreamReader(System.in));static StringTokenizer strtoken = new StringTokenizer("");static String next() {try {while (!strtoken.hasMoreTokens()) //判断是否到达末尾{strtoken = new StringTokenizer(buf.readLine());}} catch (Exception e) {e.printStackTrace();}return strtoken.nextToken();}static Integer nextInt() {return Integer.parseInt(next());}
}public class Main {public static void main(String[] args) {int[][] img;int n = reader.nextInt(), m = reader.nextInt();img = new int[n + 1][n + 1];for (int i = 0; i < m; i++) {int from = reader.nextInt(), to = reader.nextInt(), w = reader.nextInt();img[from][to] = w;img[to][from] = w;}int[] path;int index = 0;int minw = Integer.MAX_VALUE;int mini = 0;int paths = 0;int k = reader.nextInt();for (int i = 0; i < k; i++) {int count = reader.nextInt();path = new int[count];index = 0;int w = 0;for (int j = 0; j < count; j++) {path[index] = reader.nextInt();index++;}boolean beginok = false;if (img[0][path[0]] != 0) {beginok = true;w += img[0][path[0]];}boolean endok = false;if (img[path[path.length - 1]][0] != 0) {endok = true;w += img[path[path.length - 1]][0];}if (beginok && endok) {boolean connectok = false;boolean[] mark = new boolean[n + 1];int connectcount = 0;for (int j = 0; j < path.length - 1; j++) {connectok = false;if ((img[path[j + 1]][path[j]] != 0) && (!mark[path[j]])) {connectok = true;connectcount++;w += img[path[j + 1]][path[j]];mark[path[j]] = true;}if (!connectok)break;}if (connectok && connectcount == n - 1) {paths++;if (w < minw) {minw = w;mini = i + 1;}}}}System.out.println(paths);System.out.print(mini + " " + minw);}
}

7-2 网红点打卡攻略 (25 分)java版相关推荐

  1. 重返天梯-L2-036 网红点打卡攻略 (25 分)

    重返天梯-L2-036 网红点打卡攻略 (25 分) C++ 有点小坑,所以记录一下 #include <bits/stdc++.h> using namespace std; const ...

  2. L2-036 网红点打卡攻略 (25 分)(哈密顿回路)

    题目链接: 题目详情 - L2-036 网红点打卡攻略 (25 分) (pintia.cn)https://pintia.cn/problem-sets/994805046380707840/prob ...

  3. L2-036 网红点打卡攻略 (25 分)

    一个旅游景点,如果被带火了的话,就被称为"网红点".大家来网红点游玩,俗称"打卡".在各个网红点打卡的快(省)乐(钱)方法称为"攻略".你的 ...

  4. L2-4 网红点打卡攻略 (25 分)

    一个旅游景点,如果被带火了的话,就被称为"网红点".大家来网红点游玩,俗称"打卡".在各个网红点打卡的快(省)乐(钱)方法称为"攻略".你的 ...

  5. 1、网红点打卡攻略 (25 分)

    一个旅游景点,如果被带火了的话,就被称为"网红点".大家来网红点游玩,俗称"打卡".在各个网红点打卡的快(省)乐(钱)方法称为"攻略".你的 ...

  6. L2-036 网红点打卡攻略 (25 分)-PAT 团体程序设计天梯赛 GPLT

    一个旅游景点,如果被带火了的话,就被称为"网红点".大家来网红点游玩,俗称"打卡".在各个网红点打卡的快(省)乐(钱)方法称为"攻略".你的 ...

  7. L2-036 网红点打卡攻略 (25 分)(图论)

    一个旅游景点,如果被带火了的话,就被称为"网红点".大家来网红点游玩,俗称"打卡".在各个网红点打卡的快(省)乐(钱)方法称为"攻略".你的 ...

  8. 7-10 网红点打卡攻略 (25 分)——天梯赛综合练习-3

    一个旅游景点,如果被带火了的话,就被称为"网红点".大家来网红点游玩,俗称"打卡".在各个网红点打卡的快(省)乐(钱)方法称为"攻略".你的 ...

  9. 【L2-036 网红点打卡攻略】

    天梯赛L2-036 网红点打卡攻略 题目详情: 输入样例: 6 13 0 5 2 6 2 2 6 0 1 3 4 2 1 5 2 2 5 1 3 1 1 4 1 2 1 6 1 6 3 2 1 2 1 ...

最新文章

  1. 【Whalepaper】CV论文研读 - You Only Look One-level Feature (YOLOF), CVPR2021
  2. WinCE下多份BSP的维护技巧
  3. [POI2007]ZAP-Queries [HAOI2011]Problem b 莫比乌斯反演
  4. python类型转换异常捕捉_Java中的异常
  5. 2019年春季学期第四周作业
  6. 谈谈dpdk应用层包处理程序的多进程和多线程模型选择时的若干考虑
  7. 数学--数论-- HDU 2601 An easy problem(约束和)
  8. 无声也能语音识别?微软这个黑科技有点厉害
  9. asp.net mvc 发布问题
  10. 【已解决】华硕电脑关闭触摸板,安装完触摸板驱动,Fn+F9仍然无法解决问题
  11. as3 greensock_GreenSock 3 Web动画:了解GSAP的新功能
  12. 项目管理文档目录结构
  13. 前端添加登录验证码 vue
  14. linux内存高但是top进程不高,在Linux中通过Top运行进程查找最高内存和CPU使用率...
  15. tnl分析笔记之 CORBA 与假装自己是 CORBA
  16. 计算机视频的压缩方式,电脑压缩视频的方法图解步骤
  17. App推广中常用名词
  18. 12306网站服务器时间限制,12306网上订票时间限制
  19. MATLAB下机器人可视化与控制---simulink篇(1)
  20. 零基础小白如何学习角色建模?这些流程步骤你一定要知道!

热门文章

  1. ps替换模仿棒选中区域颜色
  2. 【登录页星空和捂脸动画特效】vue 实现掘金登录页捂脸动画效果,css 实现登录页星空动画流星效果【通俗易懂】
  3. i5 11300h核显相当于什么显卡
  4. OpenStack重组,敢问未来路在何方?
  5. 【老九学堂】【C++】复合类型之vector和array模板
  6. 企业运用服装erp体系后作用欠安,究竟是为什么?
  7. TIA博途SCL编程学习17_选择法排序
  8. 英语语言文学c刊,幼儿教育学年外文外文 幼儿教育学年核心期刊参考文献有哪些...
  9. 安卓手机录屏高科技,为什么还有手机无法录屏,必须要知道!
  10. c语言 测试有哪种天赋,你拥有哪一种天赋?超准测试来了