PTA 秀恩爱分得快(树)
题目
古人云:秀恩爱,分得快。
互联网上每天都有大量人发布大量照片,我们通过分析这些照片,可以分析人与人之间的亲密度。如果一张照片上出现了 K 个人,这些人两两间的亲密度就被定义为 1/K。任意两个人如果同时出现在若干张照片里,他们之间的亲密度就是所有这些同框照片对应的亲密度之和。下面给定一批照片,请你分析一对给定的情侣,看看他们分别有没有亲密度更高的异性朋友?
输入格式:
输入在第一行给出 2 个正整数:N(不超过1000,为总人数——简单起见,我们把所有人从 0 到 N-1 编号。为了区分性别,我们用编号前的负号表示女性)和 M(不超过1000,为照片总数)。随后 M 行,每行给出一张照片的信息,格式如下:
K P[1] … P[K]
其中 K(≤ 500)是该照片中出现的人数,P[1] ~ P[K] 就是这些人的编号。最后一行给出一对异性情侣的编号 A 和 B。同行数字以空格分隔。题目保证每个人只有一个性别,并且不会在同一张照片里出现多次。
输出格式:
首先输出 A PA,其中 PA 是与 A 最亲密的异性。如果 PA 不唯一,则按他们编号的绝对值递增输出;然后类似地输出 B PB。但如果 A 和 B 正是彼此亲密度最高的一对,则只输出他们的编号,无论是否还有其他人并列。
- 输入样例 1:
10 4
4 -1 2 -3 4
4 2 -3 -5 -6
3 2 4 -5
3 -6 0 2
-3 2
- 输出样例 1:
-3 2
2 -5
2 -6
- 输入样例 2:
4 4
4 -1 2 -3 0
2 0 -3
2 2 -3
2 -1 2
-3 2
- 输出样例 2:
-3 2
题解(编者的错解,能过一半,后一半其中一个错误,其他超时,不知道为什么错误,没想到什么极端样例能让其不过,思想和下面给出的正解几乎一致)
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Comparator;
import java.util.PriorityQueue;/*** @author akuya* @create 2023-10-31-15:15*/
public class love {static int N=1005;static double arr[][]=new double[N][N];static int sex[]=new int[N];static int n,m;static PriorityQueue<Integer> lpq=new PriorityQueue<>(new Comparator<Integer>() {@Overridepublic int compare(Integer o1, Integer o2) {return Math.abs(o1)-Math.abs(o2);}});static PriorityQueue<Integer> opq=new PriorityQueue<>(new Comparator<Integer>() {@Overridepublic int compare(Integer o1, Integer o2) {return Math.abs(o1)-Math.abs(o2);}});public static void main(String[] args) throws IOException {BufferedReader br=new BufferedReader(new InputStreamReader(System.in));String nm[]=br.readLine().split(" ");n=Integer.parseInt(nm[0]);m=Integer.parseInt(nm[1]);while(m--!=0){String kn[]=br.readLine().split(" ");int k=Integer.parseInt(kn[0]);for(int i=1;i<k;i++){for(int j=i+1;j<=k;j++){int x=Integer.parseInt(kn[i]);int y=Integer.parseInt(kn[j]);int ax=Math.abs(x);int ay=Math.abs(y);if(kn[i].charAt(0)=='-'){sex[ax]=-1;}else{sex[x]=1;}if (kn[j].charAt(0)=='-') {sex[ay]=-1;}else{sex[y]=1;}double ans=(double)1/k;arr[ax][ay]+=ans;arr[ay][ax]+=ans;}}}String lo[]= br.readLine().split(" ");int l=Integer.parseInt(lo[0]);int o=Integer.parseInt(lo[1]);int al=Math.abs(l);int ao=Math.abs(o);double lmax=-1;double omax=-1;for(int i=0;i<n;i++){if(l*sex[i]<0){if(arr[al][i]>lmax){lpq.clear();lpq.add(sex[i]*i);lmax=arr[al][i];}else if(arr[al][i]==lmax){lpq.add(sex[i]*i);}}}for(int i=0;i<n;i++){if(o*sex[i]<0){if(arr[ao][i]>omax){opq.clear();opq.add(sex[i]*i);omax=arr[ao][i];}else if(arr[ao][i]==omax){opq.add(sex[i]*i);}}}if(lpq.contains(o)&&opq.contains(l)){System.out.println(l+" "+o);return;}while(!lpq.isEmpty()){System.out.println(l+" "+lpq.poll());}while(!opq.isEmpty()){System.out.println(o+" "+opq.poll());}}
}
正解
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;/*** @author akuya* @create 2023-11-01-11:57*/
public class Main {static int N=1005;static List<Integer> tree =new ArrayList<>();static int n,flag=0;static int a[]=new int[N];public static void main(String[] args) {Scanner scanner=new Scanner(System.in);n=scanner.nextInt();for(int i=1;i<=n;i++) a[i]=scanner.nextInt();creat(1,n);if(tree.size()!=n){flag=1;tree.clear();creat(1,n);}if(tree.size()==n){System.out.println("YES");int len=tree.size();int log=1;for(int i:tree){if(log==len){System.out.println(i);}elseSystem.out.print(i+" ");log++;}}else System.out.println("NO");}public static void creat(int root,int last){if(root>last) return;int left=root+1;int right=last;if(flag==0){while(left<=last&&a[left]<a[root]) ++left;while(right>root&&a[right]>=a[root]) --right;}else{while(left<=last&&a[left]>=a[root]) ++left;while(right>root&&a[right]<a[root]) --right;}if(right!=(left-1)) return;creat(root+1,right);creat(left,last);tree.add(a[root]);}}
思路
这道题的思路挺简单,就是用一个动态数组存储照片中的人,用一个数组存储性别,然后n2遍历即可做出。
相关文章:
PTA 秀恩爱分得快(树)
题目 古人云:秀恩爱,分得快。 互联网上每天都有大量人发布大量照片,我们通过分析这些照片,可以分析人与人之间的亲密度。如果一张照片上出现了 K 个人,这些人两两间的亲密度就被定义为 1/K。任意两个人如果同时出现在…...
文心一言4.0对比ChatGPT4.0有什么优势?
目录 总结 文心一言4.0的优势 文心一言4.0的劣势 免费分享使用工具 后话 生成式AI的困境 “不会问”“不会用”“不敢信” 为什么要出收费版本? 目前使用过国内的文心一言3.5和WPS AI,国外的ChatGPT4.0。 文心一言和其他国内产品相比࿰…...
美观且可以很方便自定义的MATLAB绘图颜色
函数介绍 主函数是draw_test,用于测试函数。 draw_h是函数,用于给Matlab提供美观且可以很方便自定义的绘图颜色。 draw_h函数介绍 这是一个带输入输出的函数,输入1/2/3,输出下面三种颜色库的配色,每种库均有五种颜色…...
基于jsp,ssm物流快递管理系统
开发工具:eclipse,jdk1.8 服务器:tomcat7.0 数据库:mysql5.7 技术: springspringMVCmybaitsEasyUI 项目包括用户前台和管理后台两部分,功能介绍如下: 一、用户(前台)功能: 用…...
陪诊系统|挂号陪护搭建二开陪诊师入驻就医小程序
我们的陪诊小程序拥有丰富多样的功能,旨在最大程度满足现代人的需求。首先,我们采用了智能排队系统,通过扫描二维码获取排号信息,让您从繁琐的排队过程中解放出来。其次,我们提供了多种支付方式,不仅可以实…...
恒驰服务 | 华为云数据使能专家服务offering之大数据建设
恒驰大数据服务主要针对客户在进行智能数据迁移的过程中,存在业务停机、数据丢失、迁移周期紧张、运维成本高等问题,通过为客户提供迁移调研、方案设计、迁移实施、迁移验收等服务内容,支撑客户实现快速稳定上云,有效降低时间成本…...
轻量级狂雨小说cms系统源码 v1.5.2 基于ThinkPHP5.1+MySQL
轻量级狂雨小说cms系统源码 v1.5.2 基于ThinkPHP5.1MySQL的技术开发 狂雨小说cms提供一个轻量级小说网站解决方案,基于ThinkPHP5.1MySQL的技术开发。 KYXSCMS,灵活,方便,人性化设计简单易用是最大的特色,是快速架设小说类网站首选…...
Leetcode刷题详解——Pow(x, n)
1. 题目链接:50. Pow(x, n) 2. 题目描述: 实现 pow(x, n) ,即计算 x 的整数 n 次幂函数(即,xn )。 示例 1: 输入:x 2.00000, n 10 输出:1024.00000示例 2:…...
计算机毕业设计选题推荐-校园失物招领微信小程序/安卓APP-项目实战
✨作者主页:IT毕设梦工厂✨ 个人简介:曾从事计算机专业培训教学,擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Py…...
人工智能基础_机器学习011_梯度下降概念_梯度下降步骤_函数与导函数求解最优解---人工智能工作笔记0051
然后我们来看一下梯度下降,这里先看一个叫 无约束最优化问题,,值得是从一个问题的所有可能的备选方案中选最优的方案, 我们的知道,我们的正态分布这里,正规的一个正态分布,还有我们的正规方程,他的这个x,是正规的,比如上面画的这个曲线,他的这个x,就是大于0的对吧,而现实生活…...
开放式耳机能保护听力吗,开放式耳机跟骨传导耳机哪个更好?
如果从严格意义上来讲的话,开放式耳机中的骨传导耳机是能保护听力,现如今的开放式耳机是一个统称,将所有不入耳的类目全部规划到一块。因此在开放式耳机中存在着一些耳机是只能够保持周边环境音,而不是保护听力的。 下面让我来给…...
【Qt之QLocale】使用
描述 QLocale类可以在多种语言之间进行数字和字符串的转换。 QLocale类在构造函数中使用语言/国家对进行初始化,并提供类似于QString中的数字转字符串和字符串转数字的转换函数。 示例: QLocale egyptian(QLocale::Arabic, QLocale::Egypt);QString s1 …...
维修服务预约小程序的效果如何
生活服务中维修项目绝对是需求量很高的,如常见的保洁、管道疏通、数码维修、安装、便民服务等,可以说每天都有生意,而对相关维修店企业来说,如何获得更多生意很重要。 接下来让我们看看通过【雨科】平台制作维修服务预约小程序能…...
前端架构体系调研整理汇总
1.公司研发人数与前端体系 小型创业公司 前端人数: < 3 人 产品类型: 产品不是非常成熟,比较新颖。 项目流程:不完善,快、紧促,没有固定的时间排期。 技术栈: 没有历史包袱,技…...
DrawerLayout的点击事件会穿透到底部,如何拦截?
DrawerLayout实现侧后,发现了一个问题。点击DrawerLayout的画面,会触发覆盖的底层页面的控件。由此说明点击事件穿透到了底部。但是我只需要触发抽屉布局里的控件,不想触发底层被覆盖的看不见的按钮,由此我想到的时让抽屉页面拦截…...
在Spring boot中 使用JWT和过滤器实现登录认证
在Spring boot中 使用JWT和过滤器实现登录认证 一、登录获得JWT 在navicat中运行如下sql,准备一张user表 -- ---------------------------- -- Table structure for t_user -- ---------------------------- DROP TABLE IF EXISTS t_user; CREATE TABLE t_user (id int(11) …...
天堂2如何对版本里面的内容进行修改
天堂2写装备属性的问题 早一点的版本属性都是写在armor文件夹 xml档里,不再写armor里了 armor文件夹里只有防御 HP MP增加量,套装的属性都用一个技能形式写在 skills里了 在配合数据库里一个叫armorsets实现套装属性,拿皇家套做说明。 id 43…...
代码随想录Day33 LeetCode T62不同路径 LeetCode T63 不同路径II
前言 动规五部曲 1.确定dp数组含义 2.确定递推公式 3.初始化数组 4.确定遍历方式 5.打印dp数组查看分析问题 LeetCode T62 不同路径 题目链接:62. 不同路径 - 力扣(LeetCode) 题目思路: 注:n行m列而不是m行n列 1.确定dp数组含义 代表到达此下标有多少条…...
【计算机网络】分层模型和应用协议
网络分层模型和应用协议 1. 分层模型 1.1 五层网络模型 网络要解决的问题是:两个程序之间如何交换数据。 四层?五层?七层? 2. 应用层协议 2.1 URL URL(uniform resource locator,统一资源定位符&#…...
Python框架之Flask入门和视图
一、Flask入门和视图 需要安装Pycharm专业版 1. Flask简介 Python后端的2个主流框架 Flask 轻量级框架Django 重型框架 Flask是一个基于Python实现的web开发微框架 官方文档:https://flask.palletsprojects.com/ 中文文档:https://dormousehole.readthe…...
Meta亿元天团首个大模型交卷!余家辉宋飏Jason Wei耗时九个月,一雪Llama前耻
一水 发自 凹非寺量子位 | 公众号 QbitAI再见了,所有的羊驼。亚历山大王带队9个月从零重构Meta所有AI技术栈,在不断的质疑中交出超级智能实验室第一个模型:主打原生多模态的Muse Spark。模型发布后,Meta股价火速拉升约7%ÿ…...
蓝桥杯双阶乘解答
题目:代码:import java.math.BigInteger;import java.util.Scanner;// 1:无需package// 2: 类名必须Main, 不可修改public class Main {public static void main(String[] args) {Scanner scan new Scanner(System.in);//在此输入您的代码...BigInteger…...
阿里通义CosyVoice体验:上传10秒声音,生成无限语音内容
阿里通义CosyVoice体验:上传10秒声音,生成无限语音内容 1. 语音克隆技术的新突破 想象一下这样的场景:你只需要录制10秒钟的语音,就能让AI用你的声音朗读任何文本内容。这不是科幻电影,而是阿里通义实验室最新发布的…...
Java 19+ Loom生产事故复盘:某银行核心交易链路OOM崩溃始末,5个致命配置反模式曝光
第一章:Java Loom响应式编程转型的必要性与战略定位在高并发、低延迟、资源敏感型现代服务架构中,传统基于线程池的阻塞式I/O与回调驱动的响应式模型正面临双重瓶颈:JVM线程成本高企,而Project Reactor或RxJava等响应式库又引入了…...
DAMA-DMBOK中的数据治理组织架构、元数据管理实现路径、数据质量维度测量方法
针对DAMA-DMBOK框架下的这三个核心主题,以下是根据其最新版本(DMBOK2及2024年修订版)所做的深度解析,旨在为数据管理专业人士提供一个系统化的认知框架。 📊 数据治理组织架构:构建三道防线 DAMA-DMBOK指出,数据治理需要建立一个清晰的决策体系,为数据管理提供指导和…...
GitHub汉化插件终极指南:3分钟告别英文困扰,畅游中文GitHub世界
GitHub汉化插件终极指南:3分钟告别英文困扰,畅游中文GitHub世界 【免费下载链接】github-chinese GitHub 汉化插件,GitHub 中文化界面。 (GitHub Translation To Chinese) 项目地址: https://gitcode.com/gh_mirrors/gi/github-chinese …...
Lychee-Rerank在软件测试报告分析中的应用:自动归类与优先级排序
Lychee-Rerank在软件测试报告分析中的应用:自动归类与优先级排序 你是不是也遇到过这种情况?每天跑完自动化测试,面对成百上千条失败用例的日志,感觉头都大了。一条条看过去,眼睛都花了,结果发现很多失败的…...
AudioSeal Pixel Studio效果展示:蓝牙传输(SBC编码)后水印留存实测
AudioSeal Pixel Studio效果展示:蓝牙传输(SBC编码)后水印留存实测 1. 引言:当隐形水印遇上蓝牙传输 想象一下,你为一段重要的音频文件加上了数字水印,就像给它盖上了一枚隐形的数字印章。这枚印章能证明…...
RV3028-C7超低功耗RTC深度解析:UNIX时间戳与温度补偿实现
1. RV3028-C7 实时时钟模块深度技术解析RV-3028-C7 是一款面向超低功耗、高可靠性嵌入式应用的SMT封装实时时钟(RTC)模块。其核心价值不仅在于提供基础的时间保持功能,更在于将高精度时钟源、智能电源管理、非易失性配置存储与事件时间戳能力…...
开发者效率套件:OpenClaw+千问3.5-27B自动化代码审查
开发者效率套件:OpenClaw千问3.5-27B自动化代码审查 1. 为什么需要AI辅助代码审查? 作为一个长期在开源社区摸爬滚打的开发者,我经历过太多深夜提交代码后第二天被reviewer指出低级错误的尴尬时刻。直到上个月在本地部署了OpenClaw千问3.5-…...
