当前位置: 首页 > news >正文

L2-025 分而治之 - java

L2-025 分而治之


时间限制
600 ms
内存限制
64 MB


题目描述:
分而治之,各个击破是兵家常用的策略之一。在战争中,我们希望首先攻下敌方的部分城市,使其剩余的城市变成孤立无援,然后再分头各个击破。为此参谋部提供了若干打击方案。本题就请你编写程序,判断每个方案的可行性。

输入格式:
输入在第一行给出两个正整数 N 和 M(均不超过10 000),分别为敌方城市个数(于是默认城市从 1 到 N 编号)和连接两城市的通路条数。随后 M 行,每行给出一条通路所连接的两个城市的编号,其间以一个空格分隔。在城市信息之后给出参谋部的系列方案,即一个正整数 K (≤ 100)和随后的 K 行方案,每行按以下格式给出:

Np v[1] v[2] … v[Np]
其中 Np 是该方案中计划攻下的城市数量,后面的系列 v[i] 是计划攻下的城市编号。

输出格式:
对每一套方案,如果可行就输出YES,否则输出NO。


给定一个无向图,再给你k组进攻路线,判断这k组进攻路线是否可行


emmmmmmm

暴力判断即可

首先如何判断当前城市是否孤立无援呢
也就是当前城市没被攻击,且相邻城市都被攻击了,这样子该城市就是孤立无援的城市

最后就是用无向图存储,for循环暴力去判断当前方案是否可行即可


import java.io.*;
import java.math.*;
import java.util.*;public class Main
{static int N = (int) 1e4;static ArrayList<Integer> map[] = new ArrayList[N + 10]; // 存储城市static boolean vis[] = new boolean[N + 10]; // 标记当前城市是否被攻击static int n, m;static boolean check(){for (int i = 1; i <= n; i++){for (int j = 0; j < map[i].size(); j++){
//				当前城市没有被攻击且相邻国家也没有被攻击if (!vis[i] && !vis[map[i].get(j)])return false;}}return true;}public static void main(String[] args) throws IOException{n = ini();m = ini();for (int i = 1; i <= n; i++)map[i] = new ArrayList<Integer>();while (m-- > 0){int a = ini(), b = ini();map[a].add(b);map[b].add(a);}int k = ini();while (k-- > 0){int np = ini();vis = new boolean[n + 10];while (np-- > 0){int v = ini();vis[v] = true; // 当前城市被攻打了}out.println(check() ? "YES" : "NO");}out.flush();out.close();}static StreamTokenizer sc = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));static PrintWriter out = new PrintWriter(System.out);static int ini() throws IOException{sc.nextToken();return (int) sc.nval;}}

ArrayList
ArrayList


如果有说错的 或者 不懂的 尽管提 嘻嘻

一起进步!!!


闪现

http://www.lryc.cn/news/193169.html

相关文章:

  • Python+高光谱数据预处理-机器学习-深度学习-图像分类-参数回归
  • 免费 AI 编程助手 Amazon CodeWhisperer 体验
  • 【Linux】从零开始学习Linux基本指令(一)
  • Java GC 算法
  • vue3 v-html中使用v-viewer
  • Leetcode算法解析——查找总价格为目标值的两个商品
  • unity游戏开发引擎unity3D开发
  • iptables
  • 竞赛 深度学习LSTM新冠数据预测
  • Spark入门
  • react–antd 实现TreeSelect树形选择组件,实现点开一层调一次接口
  • android 固定进度环形刷新效果
  • python jieba 词性标注 中文词性分类 nlp jieba.posseg
  • LeetCode 每日一题 2023/10/9-2023/10/15
  • 相似性搜索:第 3 部分--混合倒排文件索引和产品量化
  • 小程序使用uni.createAnimation只执行一次的问题
  • win10取消ie浏览器自动跳转edge浏览器
  • 目录启示:使用 use 关键字为命名空间内的元素建立非限定名称
  • Go语言介绍与安装
  • 常用傅里叶变换表
  • 生活中的视音频技术
  • 一种用于肽图分析的烷化剂,Desthiobiotin-Iodoacetamide
  • 【(数据结构) —— 顺序表的应用-通讯录的实现】
  • macbook磁盘清理免费教程分享
  • cartographer_ros数据加载与处理
  • 设计模式-7种结构型模式
  • 华为李鹏:加速5G商业正循环,拥抱更繁荣的5.5G(5G-A)
  • Marin说PCB之CoilcraftBourns POC 电感的性能对比
  • 聊聊Maven的依赖传递、依赖管理、依赖作用域
  • centos6/7 SOCKS5 堆溢出漏洞修复(RPM方式)curl 8.4 CVE-2023-38545 CVE-2023-38546