Codeforces Round #837 (Div. 2) A-C

news2025/1/12 20:55:44

A. Hossam and Combinatorics

A题意:

给你n个数,让你求有多少个数对(i,j)1<=i,j<=n  并且 i!=j满足|s_i-s_j|等于数组中最大的绝对值之差。

思路:直接找最大值和最小值,如果最大值和最小值不是一个,那就是最大数的数量乘最小值的数量乘2:如果是一个(数组元素完全相等),那就是(n-1)*n。

代码:


#include<cstdio>
#include <iostream>
#include <algorithm>
#include <string.h>
#include <string>
#include <math.h>
#include<vector>
#include<queue>
#include<map>
#define sc_int(x) scanf("%d", &x)
#define sc_ll(x) scanf("%lld", &x)
#define pr_ll(x) printf("%lld", x)
#define pr_ll_n(x) printf("%lld\n", x)
#define pr_int_n(x) printf("%d\n", x)
#define ll long long 
using namespace std;

const int N=1000000+100;
int n ,m,h;
ll s[N];
map<ll,ll>q;


int main()
{
	int t;
	cin>>t;
	while(t--)
	{
		q.clear();
		cin>>n;
		for(int i =1;i<=n;i++)
		{
			cin>>s[i];
			q[s[i]]++;
		}

		sort(s+1,s+1+n);
		if(s[1]!=s[n])
		cout<<(ll)2*(q[s[1]]*q[s[n]])<<endl;
		else {
			cout<<(ll)(n-1)*n<<endl;
		}
	}
	
	return 0;
}

B. Hossam and FrienB

B题意:

给你一个n代表有n个人,以及m个数对(i,j)代表i,j不是朋友,定义从好友A开始到好友b结束的队列子段为[A, A +1, A +2,…,b]。如果该字段中的所有数对(i,j)都是朋友,那么这个字段就是友好的字段(定义),Hossam想知道有多少对(a,b)(1≤a≤b≤n),使得从朋友a开始到朋友b结束的子段是好的。

思路:因为知道不是朋友的数对,那么对于所有(i,j) (i<j,如果不小于就swap一下就好)不是朋友,如果要找是朋友的数对就是找没有包含(i,j)的范围的区间,那么我们可以从后面往前面找,因为对于后面的每一个i,只要发现当前i位置有没有存在的区间(i,j)不是朋友,如果有就用最小的那一个直接进行更新,如果没有就可以直接加上那一段可以加的范围、

(注意:假设后面有一段(3,5)不是朋友的话,那么前面的1,2,3是无论如何都走不到5的)。

代码:


#include<cstdio>
#include <iostream>
#include <algorithm>
#include <string.h>
#include <string>
#include <math.h>
#include<vector>
#include<queue>
#include<map>
#define sc_int(x) scanf("%d", &x)
#define sc_ll(x) scanf("%lld", &x)
#define pr_ll(x) printf("%lld", x)
#define pr_ll_n(x) printf("%lld\n", x)
#define pr_int_n(x) printf("%d\n", x)
#define ll long long 
using namespace std;

const int N=1000000+100;
int n ,m,h;
ll s[N];

map<int,int>q;
vector<int>ss[N];

int main()
{
	int t;
	sc_int(t);
	while(t--)
	{

		cin>>n>>m;
		for(int i =1;i<=n;i++)ss[i].clear();
		while(m--)
		{
			int x,y;
			sc_int(x),sc_int(y);
			if(x>y)swap(x,y);
			if(!ss[x].size())
			ss[x].push_back(y);
			else if(ss[x][0]>y){
			ss[x].pop_back();
			ss[x].push_back(y);
			}
		}
		ll res=0;
		int sum=n+1;

		for(int i =n-1;i>=1;i--)
		{
				if(!ss[i].size()) res+=sum-i-1;
				else {
					sum=min(sum,ss[i][0]);					
					res+=sum-i-1;
				}
		}
		pr_ll_n(res+n);
	}
	
	return 0;
}

C. Hossam and Trainees

C题目意思:

给你n个数,问有没有两个数的最大公约数大于等于2.

思路:一开始想着用筛法筛,但是没有想到通过有限个质数来筛(我就嗯筛tm的),导致后面没做出来qwq。

首先要求存不存在两个数的最大公约数大于等于2,那么就是问存不存在两个数的因子有没有公共的质数(非质数也可以由质数组成),那么我们可以去找sqrt(1e9)的质数(这里我直接用1e5了)然后用欧拉筛把质数先筛出来。

然后对于每次输入的数,可以用试除法筛质数,筛的过程中把数保存一下,如果重复出现了就直接保存一下。

这里主要要注意的点就是当前我们的素数的平方大于我们的这个要筛的数的时候,就应该退出了(因为已经没有除了它本身外可以筛的素数了),不然就会狠狠的t!

代码:


#include<cstdio>
#include <iostream>
#include <algorithm>
#include <string.h>
#include <string>
#include <math.h>
#include<vector>
#include<queue>
#include<map>
#define sc_int(x) scanf("%d", &x)
#define sc_ll(x) scanf("%lld", &x)
#define pr_ll(x) printf("%lld", x)
#define pr_ll_n(x) printf("%lld\n", x)
#define pr_int_n(x) printf("%d\n", x)
#define ll long long 
using namespace std;

const int N=1000000+100;
int n ,m,h;
ll s[N];
vector <ll> pr;bool st[N];
map<int,int>q;

void slove()
{

	sc_int(n);
	bool st=0;
	for(int i=1;i<=n;i++)
	{
		sc_ll(s[i]);
		if(st)continue;
		for(int j=0;j<pr.size();j++)
		{
			if((ll)pr[j]*pr[j]>s[i])break;//注意退出
			if(s[i]%pr[j]==0)
			{
				if(q[pr[j]]) st=1;
				q[pr[j]]++;
				while(s[i]%pr[j]==0)
				s[i]/=pr[j];
			}
		}
		if(s[i]>1){
			if(q[s[i]])st=1;
			q[s[i]]++;
		}
	}
	if(st)printf("YES\n");
	else cout<<"NO\n";
}

int main()
{

	for(int i=2;i<=110000;i++)//筛1e5的素数
	{
		if(!st[i])pr.push_back(i);
		for(int j=0;pr.size()>j&&pr[j]<=110000/i;j++)
		{
			st[pr[j]*i]=1;
			if(!i%pr[j])break;
		}
	}
	
	int t;
	sc_int(t);
	while(t--){
		slove();
	q.clear();		
	}
	
	return 0;
}

感觉这一次C能做出来,但是就是差一点思路和时间(B卡太久了),还是得多锻炼下思维qwq

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/85981.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

前端基础(一)_前端页面构成

一、前端页面构成 1.HTML(Hypertext Markup Language) Html–超文本标记语言&#xff0c; 结构层由HTML标记语言创建的&#xff0c;负责页面的语义。&#xff08;它包括一系列标签&#xff0c;主要分为块标签和行标签、行内块标签三类&#xff09; 2.CSS(Cascading style sh…

绿色中国馆设计

目 录 1工程概况 1 1.1建筑设计部分 1 1.1.1设计依据 1 1.1.2设计内容、建筑面积、标高 1 1.1.3建筑空间构成 1 1.1.4采光和通风 1 1.1.5防火及安全 2 1.1.6各部分工程构造 2 1.2 结构设计部分 3 1.2.1基本资料 3 1.2.2结构形式和基础形式 3 1.2.3结构尺寸及采用的材料 4 1.2.4…

[oeasy]python0029_放入系统路径_PATH_chmod_程序路径_执行原理

放入路径 回忆上次内容 上次总算可以把 sleep.py 直接执行了 sleep.py文件头部要声明好打开方式 #!/usr/bin/python3用的是 python3 解释 sleep.py 修改 sleep.py 文件 的执行权限 给当前用户增加 执行execute 权限 chmod ux sleep.py 运行./sleep.py成功 但我不想总带着当前路…

[附源码]Python计算机毕业设计SSM基于web的网上订餐系统(程序+LW)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Ubuntu18.04安装Carla 记录

官方文档&#xff1a;CARLA Simulator 方式一&#xff1a;简单快速安装&#xff0c;该方式有缺陷。需要使用虚幻引擎编辑器的高级定制和开发选项不可用。 Advanced customization and development options that require use of the Unreal Engine editor are not available b…

【编译原理】第三章部分课后题答案

第 三 章 课 后 习 题 T 3.1 考虑文法 S→(L)∣aL→L,S∣SS \rightarrow (L)\space | \space a\\ L\rightarrow L, S \space | \space S S→(L) ∣ aL→L,S ∣ S (a) 建立句子 (a,(a,a))(a,(a,a))(a,(a,a)) 和 (a,(a,a),(a,a))(a,(a,a),(a,a))(a,(a,a),(a,a)) 的分析树。 见…

SpringMVC学习:三、SpringMVC的请求与响应

4. SpringMVC的请求与响应 4.1 RequestMapping ​ 使用RequestMapping注解可以定义不同的处理器映射规则。 1. URL路径映射: RequestMapping(value“/queryAll”)或RequestMapping("/queryAll”&#xff09; value的值是数组&#xff0c;可以将多个url映射到同一个方法…

计算机研究生就业方向之互联网安全

我一直跟学生们说你考计算机的研究生之前一定要想好你想干什么&#xff0c;如果你只是转码&#xff0c;那么你不一定要考研&#xff0c;至少以下几个职位研究生是没有啥优势的&#xff1a; 1&#xff0c;软件测试工程师&#xff08;培训一下就行&#xff09; 2&#xff0c;前…

CSS 居中总结

文章目录CSS 居中总结水平居中文字水平居中块元素水平居中行内元素和行内块元素水平居中垂直居中文字垂直居中单行文字多行文字块元素居中块元素居中&#xff08;方法二&#xff09;块元素居中&#xff08;方法三&#xff09;行内元素、行内块元素居中flex居中CSS 居中总结 水…

web前端期末大作业实例 (1500套) 集合

文章目录&#x1f4da;web前端期末大作业 (1500套) 集合一、网页介绍二、网页集合&#x1f48c;表白网页 125套 (集合)&#x1f499;Echarts大屏数据展示 150套 (集合)一、基于HTMLEcharts技术制作二、基于VUEEcharts技术制作&#x1f381;更多源码&#x1f4da;web前端期末大作…

去中心化的互联网环境,有一种神奇的商业模式,无产品也可以创业

现在的电商行业做分销的平台越来越多&#xff0c;竞争力也越渐增大&#xff0c;不得不使用一些电商商业模式来让用户进来并留下来。 ​ 但是在经济环境和疫情环境的双重影响下&#xff0c;每个人或多或少都被影响到了。虽然有很多行业低落&#xff0c;但是也有一些行业兴起&…

Spring事务及Spring整合MyBatis

SM整合的步骤 1&#xff0c;建库建表 2&#xff0c;新建maven模块 3&#xff0c;修改maven目录 4&#xff0c;修改pom.xml文件&#xff0c;添加依赖 5&#xff0c;添加MyBaits模板&#xff08;SqlMapperConfig.xml和XXXMapper.xml文件&#xff09; 6&#xff0c;添加Appli…

小程序中的轮播图

目录 小程序的宿主环境 - 组件 1.scroll-view 组件的基本使用2.swiper 和 swiper-item 组件的基本使用3.text 组件的基本使用4.rich-text 组件的基本使用附&#xff1a;微信小程序轮播图单独添加图片、修改轮播图图片、单独修改某张图片总结 小程序的宿主环境 - 组件 1.scrol…

北京智和信通:交换机策略查询与自动化配置

在网络中交换机占据重要位置&#xff0c;一旦交换机被攻击或破坏&#xff0c;都将使整个网络处于危险之中。在网络的日常配置管理中&#xff0c;交换机的配置也是核心工作&#xff0c;但在交换机的配置过程复杂&#xff0c;而且根据品牌及型号的不同&#xff0c;配置方式也不相…

利用2阶分数阶微分掩模的边缘检测(Matlab代码实现)

&#x1f468;‍&#x1f393;个人主页&#xff1a;研学社的博客 &#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜…

java计算机毕业设计基于安卓Android的装维助手APP

项目介绍 随着科学技术的飞速发展,各行各业都在努力与现代先进技术接轨,通过科技手段提高自身的优势&#xff1a;对于装维助手APP当然也不能排除在外,随着网络技术的不断成熟,带动了装维助手APP,它彻底改变了过去传统的管理方式,不仅使服务管理难度变低了,还提升了管理的灵活性…

服务器负载过高实例分析

一、问题现象 top 命令查看显示服务器负载情况&#xff0c;服务器负载1.31&#xff0c;而且长时间没降下去&#xff0c;CPU使用率99.9%也异常飚高 load average &#xff1a;系统平均负载均值&#xff0c;三列分别代表 1分钟、5分钟、15分钟。理论上&#xff0c;值越小越好。负…

C4D中使用python脚本1

学习视频链接 关于C4D与Python那些事_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1et411172W/ 目录 一、简单用法 二、C4D包 2.1 vector 矢量 2.2 矩阵 2.3 用脚本创建对象 2.4 几何体结构 三、制作效果 3.1 洗牌 3.2 后面的项目单独开文章 一、简单用法 …

java小技能:对list集合根据条件进行分组、过滤和字段筛选

文章目录 引言I 对list根据条件进行分组1.1 费率信息实体1.2 dto1.3 查询数据II 对list根据条件进行过滤和字段筛选1.1 代理商配置角色权限步骤1.2 实体1.3 穿透删除所有下级代理商相对应的权限值引言 需求背景:查询机构下的代理商费率信息,查询结果对分润和返利进行分组。 …

【云计算与大数据技术】Spark的解析(图文解释 超详细必看)

一、Spark RDD Spark是一个高性能的内存分布式计算框架&#xff0c;具备可扩展性&#xff0c;任务容错等特性&#xff0c;每个Spark应用都是由一个driver program 构成&#xff0c;该程序运行用户的 main函数 。 Spark提供的一个主要抽象就是 RDD(Resilient Distributed Data…