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 顶格输出,中间没有空格 样例输入 一个满足题目要求的输入范例. ...
随机推荐
- 【hdu1006】解方程
http://acm.hdu.edu.cn/showproblem.php?pid=1006 这题坑了我好久,发现居然是一个除法变成了整除,TAT,所以建议在写较长的运算表达式的时候出现了除法尽量加个 ...
- Mysql 常用函数(11)- trim 函数
Mysql常用函数的汇总,可看下面系列文章 https://www.cnblogs.com/poloyy/category/1765164.html trim 的作用 删除字符串左右两侧的空格 tri ...
- AOP行为日志
最近新项目要记录行为日志,很久没有用AOP,研究了一下. 废话补多少,先上个流程图: 数据库日志表设计 字段名称 字段类型 注释 LOG_ID VARCHAR2(255) LOG_LEVEL N ...
- mybatis部分sql技巧
1.mybatis中没有<=号,必须用<![CDATA[<=]]>表示.<update id="reduceNumber"> UPDATE se ...
- java ->String、StringBuffer、StringBuilder三者之间的区别
1.首先说运行速度,速度由快到慢排列:StringBuilder > StringBuffer > String String最慢的原因: String为字符串常量,而StringBuil ...
- shell脚本常用命令汇总
一.shell脚本概述和入门 (1)shell脚本是一个命令行解释器,它接收应用程序/用户命令,然后调用操作系统内核 (2)shell脚本的常用执行方式: 第一种:采用bash或sh+脚本的相对路径或 ...
- SpringCloud Netflix (五) : Hystrix 服务熔断和服务降级
什么是Hystrix 在分布式环境中,许多服务依赖项中的一些服务依赖不可避免地会失败.Hystrix是一个库,通过添加延迟容忍和容错逻辑,帮助您控制这些分布式服务之间的交互.Hystrix通过隔离服务 ...
- wepy 小程序开发(interceptor拦截器 && WXS)
WePY全局拦截器可对原生API的请求进行拦截. import wepy from 'wepy'; export default class extends wepy.app { constructo ...
- node的fs模块
node的file system模块提供的api有同步和异步两种模式(大多数情况下都是用的异步方法,毕竟异步是node的特色,至于提供同步方法,可能应用程序复杂的时候有些场景使用同步会比较合适).异步 ...
- Java基础之值传递
一.传递类型 我们从c语言开始学习程序设计语言时就知道,参数的传递类型一般有两种:值传递和引用传递.那么什么是值传递什么是引用传递呢? 值传递:指在调用方法时将实际参数的值拷贝一份传递给方法,这样方法 ...