Java实现蓝桥杯 算法训练 Professor Monotonic's Network
试题 算法训练 Professor Monotonic’s Network
资源限制
时间限制:1.0s 内存限制:256.0MB
问题描述
无聊的教授最近在做一项关于比较网络的实验。一个比较网络由若干个含两个输入端和两个输出端的比较器组成。如下图,一个比较器将会比较它的两个输入端的值i1和i2,把它们防止在输出端o1和o2上使得o1<=o2。
一个比较网络有n个输入端a1,a2,…,an和n个输出端b1,b2,…,bn。对于每个比较器,它的输入端要么直接连在比较网络的输入端上,要么连在另一个个比较器的输出端上。这样的关系组成的有向图是无环的。下图给出了一个拥有4个输入端、4个输出端、5个比较器的比较网络。
在比较网络运行时,值从输入端输入,然后比较器开始工作。当然,一个比较器仅当它的所有输入值已经被算出来后才能开始工作。假设一个比较器需要1单位时间来工作。那么,上面的例子中的比较网络需要3单位时间来计算输出值。图中的comp-1和comp-2是并行工作的,comp-3和comp-4也是,comp-5只有等comp-3和comp-4完成后才能工作。
无聊的教授现在需要帮助确定那些比较网络是排序网络,并且它们需要多长时间来计算输出值。一个排序网络是一个比较网络,并且无论输入如何,它的输出都单调增。上面的例子也是一个比较网络。因为对于每一种可能的输入,输出值都存在关系b1<=b2<=b3<=b4。
输入格式
第一行两个整数n,k,分别表示输入值的个数和比较器的个数。
它们满足1<=n<=12,0<=k<=150。
之后从左到右依次给出每个比较器的信息
之后每行两个整数x,y表示第i个比较器将ax,ay做了比较,把其中较小的数放回ax,较大的数放回ay。
输出格式
第一行输出YES或NO表示该比较网络是否是排序网络
第二行输出一个整数表示该比较网络的运行时间。
样例输入
样例1:
4 5
1 2
3 4
1 3
2 4
2 3
样例2:
8 0
样例3:
3 3
1 2
2 3
1 2
样例输出
样例1:
YES
3
样例2:
NO
0
样例3:
YES
3
样例说明
样例1即图片上所给的比较网络。
package 第九次模拟;
import java.util.Scanner;
public class 排序 {
public static class Node{
int first;
int second;
}
static int n=0,m=0,x=0,y=0;
static int N=15;
static int []a = new int [N];
static int [] num = new int [N];
static int res=0;
static int cnt=0;
static Node [] T = new Node[155];
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int m = sc.nextInt();
while(m-->0){
x= sc.nextInt();
y = sc.nextInt();
T[++cnt]=new Node();
T[cnt].first=x;
T[cnt].second=y;
int t =Math.max(num[x], num[y])+1;
num[x]=t;
num[y]=t;
res=Math.max(res, t);
}
sc.close();
boolean yes=true;
for(int i=0;i<(1<<n);i++){
for(int j=0;j<n;j++){
a[j+1]=(i>>j&1);
}
for(int j=1;j<=cnt;j++){
x=T[j].first;
y=T[j].second;
int tt=Math.min(a[x],a[y]);
a[y]=Math.max(a[x],a[y]);
a[x]=tt;
}
for(int j=1;j<n;j++)
if(a[j]==1&&a[j+1]==0){
yes=false;break;
}
if(!yes)
break;
}
if(yes)
System.out.println("YES");
else
System.out.println("NO");
System.out.println(res);
}
}
package 第九次模拟;
import java.util.Scanner;
public class 排序 {
//转自https://blog.csdn.net/a1439775520/article/details/104653580
public static class Node{
int first;
int second;
}
public static void main(String[] args) {
int n=0,m=0,x=0,y=0;
int N=15;
int [] num = new int [N];
int res=0;
int cnt=0;
int t=0;
Node [] T = new Node[155];
Scanner sc = new Scanner(System.in);
n = sc.nextInt();
m = sc.nextInt();
while(m-->0){
x= sc.nextInt();
y = sc.nextInt();
T[++cnt]=new Node();
T[cnt].first=x;
T[cnt].second=y;
t = Math.max(num[x], num[y])+1;
num[x]=t;
num[y]=t;
res= Math.max(res, t);
}
sc.close();
int []a = new int [N];
int tt=0;
// boolean yes=true;
for(int i=0;i<(1<<n);i++){
for(int j=0;j<n;j++){
a[j+1]=(i>>j&1);
}
for(int j=1;j<=cnt;j++){
x=T[j].first;
y=T[j].second;
tt= Math.min(a[x],a[y]);
a[y]= Math.max(a[x],a[y]);
a[x]=tt;
}
for(int j=1;j<n;j++)
if(a[j]==1&&a[j+1]==0){
System.out.println("NO");
System.out.println(res);return;
}
// if(!yes)
// break;
}
// if(yes)
System.out.println("YES");
// else
// System.out.println("NO");
System.out.println(res);
}
// public static int min(int a,int b){
// return a<b?a:b;
// }
// public static int max(int a,int b){
// return a<b?b:a;
// }
}
Java实现蓝桥杯 算法训练 Professor Monotonic's Network的更多相关文章
- Java实现 蓝桥杯 算法训练 猴子吃包子(暴力)
试题 算法训练 猴子吃包子 问题描述 从前,有一只吃包子很厉害的猴子,它可以吃无数个包子,但是,它吃不同的包子速度也不同:肉包每秒钟吃x个:韭菜包每秒钟吃y个:没有馅的包子每秒钟吃z个:现在有x1个肉 ...
- Java实现蓝桥杯 算法训练 大等于n的最小完全平方数
试题 算法训练 大等于n的最小完全平方数 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 输出大等于n的最小的完全平方数. 若一个数能表示成某个自然数的平方的形式,则称这个数为完全平 ...
- java实现 蓝桥杯 算法训练 Password Suspects
问题描述 在年轻的时候,我们故事中的英雄--国王 Copa--他的私人数据并不是完全安全地隐蔽.对他来说是,这不可接受的.因此,他发明了一种密码,好记又难以破解.后来,他才知道这种密码是一个长度为奇数 ...
- Java实现 蓝桥杯 算法训练VIP 报数(暴力+数学)约瑟夫环问题
试题 算法训练 报数 问题描述 现有n个同学站成一圈,顺时针编号1至n.从1号同学开始顺时针1/2报数,报到1的同学留在原地,报到2的同学退出圆圈,直到只剩一名同学为止.问最后剩下的同学编号. 输入格 ...
- Java实现蓝桥杯 算法训练 ALGO-15 旅行家的预算
问题描述 一个旅行家想驾驶汽车以最少的费用从一个城市到另一个城市(假设出发时油箱是空的).给定两个城市之间的距离D1.汽车油箱的容量C(以升为单位).每升汽油能行驶的距离D2.出发点每升汽油价格P和沿 ...
- Java实现 蓝桥杯 算法训练 审美课
算法训练 审美课 时间限制:1.0s 内存限制:256.0MB 提交此题 问题描述 <审美的历程>课上有n位学生,帅老师展示了m幅画,其中有些是梵高的作品,另外的都出自五岁小朋友之手.老师 ...
- Java实现 蓝桥杯 算法训练 多阶乘计算
试题 算法训练 多阶乘计算 问题描述 我们知道,阶乘n!表示n*(n-1)(n-2)-21, 类似的,可以定义多阶乘计算,例如:5!!=531,依次可以有n!..!(k个'!',可以简单表示为n(k) ...
- Java实现 蓝桥杯 算法训练 找零钱
试题 算法训练 找零钱 问题描述 有n个人正在饭堂排队买海北鸡饭.每份海北鸡饭要25元.奇怪的是,每个人手里只有一张钞票(每张钞票的面值为25.50.100元),而且饭堂阿姨一开始没有任何零钱.请问饭 ...
- Java实现 蓝桥杯 算法训练 第五次作业:字符串排序
试题 算法训练 第五次作业:字符串排序 问题描述 输入一个小写字符串,按从小到大的顺序输出. 输入格式 bcaed 输出格式 abcde 顶格输出,中间没有空格 样例输入 一个满足题目要求的输入范例. ...
随机推荐
- Android 8.1 关机充电动画(三)Android模式
system:Android 8.1 platform:RK3326/PX30 uboot kernel system/core/healthd Android 8.1 关机充电动画(一)模式选择 A ...
- spring mvc --自定义converse
在MVC中我们可以很轻松的根据项目需求进行必要的信息转换,如设置默认的日期格式,自定义String类型的格式等等... 配置中我们需要自定义converseService: <bean id=& ...
- 「雕爷学编程」Arduino动手做(29)——DS1302时钟模块
37款传感器与模块的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止37种的.鉴于本人手头积累了一些传感器和模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的,这里 ...
- Appium自动化(15) - 针对 webview 进行自动化测试
如果你还想从头学起Appium,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1693896.html webview 简介 WebVie ...
- 流复制-pg_basebackup (有自定义表空间)
一.组成部分 1.walsender进程是用来发送WAL日志记录的 2.walreceiver进程是用来接收WAL日志记录的 3.startup进程是用来apply日志的 二.主库配置 1.授权账号, ...
- poj1149 经典建模
http://wenku.baidu.com/view/0ad00abec77da26925c5b01c.html 以上内容均为转载 #include<queue> #include< ...
- Java——连接MySql数据库
eclipse项目文件结构 /JavaConnMySqlTest/src/db.properties jdbc.drivers=com.mysql.jdbc.Driver jdbc.url=jdbc: ...
- Kubectl exec 的工作原理解读
对于经常和 Kubernetes 打交道的 YAML 工程师来说,最常用的命令就是 kubectl exec 了,通过它可以直接在容器内执行命令来调试应用程序.如果你不满足于只是用用而已,想了解 ku ...
- (三)vue数据绑定及相应的命令
vue数据绑定及相应的命令 {{ Text }} 双括号进行数据渲染 动态绑定数据 例如:{{message}} data: { return{ message: 'Hello Vue!' } } 2 ...
- ubuntu18.04.4安装k8s
k8s部署 1.集群所有主机关闭swap sudo swapoff -a sudo sed -i 's/.*swap.*/#&/' /etc/fstab 如果重启后swap还是自动挂载执行sy ...