2023/3/21总结

题解:

E - 2xN Grid (atcoder.jp)

1.这一题,就是求出第一行与第二行相对应的相同数字的个数,看数据有多大,我们就知道,这道题目,是不可能穷举的。

2.因此,我们需要 找到规律去写它。此题需要用到前缀和算法。

3.我们需要记录数字和他所在的区间。然后根据区间的位置去判断,该数是否在俩列重合,从而,去相加对应的区间。

代码如下:

#include<stdio.h>
#define N 100010
struct node
{
	long long x;
	long long count;
}a[N][2];
int main()
{
	long long l,n1,n2,i,x,y,j,sum,max;
	scanf("%lld%lld%lld",&l,&n1,&n2);
	for(i=1;i<=n1;i++)
	{
		scanf("%lld %lld",&a[i][0].x,&a[i][0].count);
		a[i][0].count+=a[i-1][0].count;
	}
	for(i=1;i<=n2;i++)
	{
		scanf("%lld %lld",&a[i][1].x,&a[i][1].count);
		a[i][1].count+=a[i-1][1].count;
	}
	sum=0;
	for(i=1,j=1;i<=n1&&j<=n2;)
	{
		if(a[i][0].x==a[j][1].x)
		{
			if(a[i][0].count<a[j][1].count&&a[j-1][1].count<a[i][0].count)
			{
				if(a[j-1][1].count>a[i-1][0].count)
				{
					max=a[j-1][1].count;
				}
				else max=a[i-1][0].count;
				
				sum+=a[i][0].count-max;
				i++;
			}
			else if(a[i][0].count>=a[j][1].count&&a[j][1].count>a[i-1][0].count)
			{
				if(a[j-1][1].count>a[i-1][0].count)
				{
					max=a[j-1][1].count;
				}
				else max=a[i-1][0].count;
				
				sum+=a[j][1].count-max;
				j++;
			}
			else if(a[i][0].count<a[j][1].count)
			{
				i++;
			}
			else if(a[i][0].count>=a[j][1].count)
			{
				j++;
			}
		}
		else if(a[i][0].count<a[j][1].count)
		{
			i++;
		}
		else if(a[i][0].count>a[j][1].count) j++;
		else 
		{
			i++,j++;
		}
	}
	printf("%lld\n",sum);
}

 Problem - B - Codeforces

1.这一题说,只需要比较大小即可,如果它能拿的大,我们可以安排让他先拿完,保证永远比另外一个大

代码:

#include<stdio.h>
#define N 110
int a[N];
int main()
{
	int t,n,i,s1,s2;
	scanf("%d",&t);
	while(t--)
	{
		s1=s2=0;
		scanf("%d",&n);
		for(i=0;i<n;i++)
		{
			scanf("%d",&a[i]);
			if(a[i]%2==0) s1+=a[i];
			else s2+=a[i];
		}
		if(s1>s2) puts("YES");
		else puts("NO");
	}
	return 0;
}

 Problem - C - Codeforces

1.这道题暴力枚举即可,我们去枚举每一个位置的后一个位置,以及后一个位置每次跳俩次,不相等即可,如果相等就一定是NO,否则是YES

代码:

#include<stdio.h>
int main()
{
	int t,i,j,n;
	char s[2010];
	scanf("%d",&t);
	while(t--)
	{
	    int	flag=1;
		scanf("%d",&n);
		scanf("%s",s);
		for(i=0;i<n&&flag;i++)
		{
			for(j=i+1;j<n;j+=2)
			{
				if(s[i]==s[j]) 
				{
					flag=0;
					break;
				}
			}
		}
		if(flag) puts("YES");
		else puts("NO");
	}
}

 Problem - D - Codeforces

1.利用前缀和思想,去求出所有的前面的总和,然后减去区间的值,最后加上k*(r-l+1)判断奇数偶数即可

代码:

#include<stdio.h>
#define N 200010
int a[N];
int b[N];
int main()
{
	int t,n,q,i,l,r,k;
	scanf("%d",&t);
	while(t--)
	{
	//	sum=0;
		b[0]=0;
		scanf("%d%d",&n,&q);
		for(i=1;i<=n;i++)
		{
			scanf("%d",&a[i]);
			b[i]=a[i]+b[i-1];
		}
		for(i=0;i<q;i++)
		{
			scanf("%d%d%d",&l,&r,&k);
		//	printf("%d\n",b[n]-(b[r]-b[l-1])+k*(r-l+1));
			if((b[n]-(b[r]-b[l-1])+k*(r-l+1))%2) puts("YES");
			else puts("NO");
		}
	}
	
	return 0;
}

 

我这俩天试着写了很多题,但是提交上去不是TLE就是WA。所以那些题在没有写出来之前就并没有写题解了。

java知识点

java的控制台输入由system.in()完成。

用BufferedReader对象创建后,我们使用read()方法去从控制台读取一个字符,或者用readLine()方法读取一个字符串.

scanner类用于输入

next()获取字符串类似于c语言里面的scanf(“%s”),而nextLine()获取字符串很像gets。

输入int或者float类型的数据,输入之前最好使用hasNextXxx方法进行验证,再使用nextXxx来获取。

输入int时nextInt,float是nextFloat

读写文件是俩个流

FileInputStream和FileOutputStream

读取:

InputStream f=new FileInputStream(“工作目录”)

或者

File f=new File(“”);

InputStream in =new FileInputStream(f)

写入:

OutputStream f = new FileOutputStream(“”)

或者

File f = new File(“”);

OutputStream fout=new FileOutputSTream(f)

一些操作:

close()

write(int w) throws IOExpception{}

指定的字节写到输出流中

write(byte[] w)

把指定数组中w数组的长度字节写到OutputStream中

集合

java中集合框架有主要包括俩种类型的容器,一个是集合类collection,存储元素集合,一个是图Map,存储对应键、值对映射。集合类对应list、Set、Queen、抽象类、具体类(ArrayList、LinkedList、HashSet……)

集合框架包含以下内容:

接口:指代表集合的抽象数据类型。

实现(类)是集合接口的具体实现

算法:实现集合接口的对象里面的方法执行的一些有用的计算

内部类

定义在其他类内部的类称为内部类,也叫嵌套类,包含内部类的类也被称为外部类。

内部类比外部类可以多使用三个修饰符,private、protected、static——外部类不可以使用这三个修饰符。

静态内部类

如果使用static修饰一个内部类,那么这个内部类属于外部类本身,而不属于外部类的某一个对象。使用static修饰的内部类被称为类内部类,也称为静态内部类。

接口里面定义的内部类默认使用public static修饰,接口内部类只能是静态内部类。

如果希望在外部类以外的地方访问内部类,内部类不能使用public访问控制权限,private修饰的内部类只能在外部类内部使用。

局部内部类

把内部类放在方法里面定义,就叫这个内部类为局部内部类,局部内部类仅仅在该方法里面有效。局部内部类不能使用访问控制符和static修饰符修饰。

匿名内部类

匿名内部类只适合创建只需要使用一次的类,匿名内部类不能重复使用。

定义格式如下:

new 实现接口() //或者父类构造器(实参列表)

{

                //匿名内部类的类体部分

}

匿名内部类必须继承一个父类或者实现一个接口,但是最多只能继承一个父类和一个接口。

匿名内部类不能是抽象类,系统创建匿名内部类时,会创建匿名内部类的对象。

匿名内部类不能定义构造器,因为匿名内部类没有类名,所以无法定义构造器。但是它可以定义初始化块。

Lambda表达式允许使用更简洁的代码来创建一个抽象方法的接口(这种接口被称为函数式接口)

Lambda表达式语法:

(参数) ->(表达式)

或者

(参数)->{ (表达式);}

可以不声明参数类型,系统会识别,一个参数可以不订阅圆括号,但是多个参数需要。如果只有一个语句则不需要大括号,如果只有一个表达式,那么系统会自动返回,如果不是需要自己指定返回。

如果Lambda表达式的代码块只有一条代码,可以在代码块种使用方法引用和构造器引用。

枚举类

java中枚举类关键字是enum。枚举类不能派生子类。默认是private修饰,也只能是private修饰。

定义:

修饰符 enum 名称

{

……

}

枚举类也可以定义成员变量、方法和构造器,也可以包含抽象方法。

枚举类也可以实现一个或者多个接口。如果枚举类实现接口类里面的方法,那么每个枚举值在调用该方法时都有相同的行为方式。

强制回收内存:system.gc();或者Runtime对象的gc()实例方法Runtime.getRuntime().gc()。

如果想让系统自动回收,使用finalize()方法

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

最新消息!信息系统项目管理师教程改版!

《信息系统项目管理师教程&#xff08;第4版&#xff09;》于2023年3月出版 新版《信息系统项目管理师考试大纲》于2023年3月出版 信息系统项目管理师教程改版说明 一、整体说明 1、教材整体说明&#xff1a;第四版教材由25章组成&#xff0c;相比第三版28章内容减少了3章主要…

硬件速攻-AT24CXX存储器

AT24C02是什么&#xff1f; AT24CXX是存储芯片&#xff0c;驱动方式为IIC协议 实物图&#xff1f; 引脚介绍&#xff1f; A0 地址设置角 可连接高电平或低电平 A1 地址设置角 可连接高电平或低电平 A2 地址设置角 可连接高电平或低电平 1010是设备前四位固定地址 &#xf…

QT | 编写一个简单的上位机

QT | 编写一个简单的上位机 时间&#xff1a;2023-03-19 参考&#xff1a; 1.易懂 | 手把手教你编写你的第一个上位机 2.QT中修改窗口的标题和图标 3.图标下载 1.打开QT Creator 2.新建工程 Qt Creator 可以创建多种项目&#xff0c;在最左侧的列表框中单击“Application”&am…

学校教的Python,找工作没企业要,太崩溃了【大四真实求职经历】

如果只靠学校学的东西去找工作&#xff0c;能找到工作吗&#xff1f; 今天给大家看一个粉丝的真实求职案例&#xff0c;想做Python方面的工作&#xff0c;投了二十几个简历却没人要&#xff0c;心态崩了。为什么没人要&#xff1f;我来告诉你答案。 然后我还会结合我的这些年的…

Linux--线程安全、多线程fork问题

目录 一、概念&#xff1a; 二、利用空格分割字符串&#xff1a; 1.代码&#xff1a; 2.结果&#xff1a; 3.解决方法&#xff1a; 三、多线程fork&#xff08;&#xff09; 1.代码&#xff1a; 2.线程id 3.增加fork&#xff08;&#xff09;代码&#xff1a; 4.改变fo…

【嵌入式硬件芯片开发笔记】HART协议调制解调芯片AD5700配置流程

【嵌入式硬件芯片开发笔记】HART协议调制解调芯片AD5700配置流程 XTAL_EN接地&#xff0c;CLK_CFG的两个引脚由同一个GPIO控制 初始时HART_CLK_CFG输出低电平 由RTS引脚控制调制/解调。当RTS处于高电平时&#xff0c;为解调&#xff08;输入&#xff09;&#xff1b;否则为调…

【计算机组成原理】:计算机系统概述

目录 一、计算机系统层次结构 1️⃣计算机系统的组成 2️⃣计算机硬件 1. 冯诺依曼机的基本思想 &#x1f4a4;思考&#xff1a;冯诺依曼机的来源❓ &#x1f338;知识点&#xff1a;冯诺依曼机的特点 &#x1f4a4;思考&#xff1a;以运算器为中心的计算机有什么缺点❓ 2…

【微服务】—— 统一网关Gateway

文章目录1. 概述1.1 为什么需要网关1.2 SpringCloud Gateway2. gateway快速入门搭建网关服务1、创建新的module&#xff0c;引入SpringCloudGateway的依赖和nacos的服务发现依赖&#xff1a;2、编写路由配置和nacos地址3. 断言工厂路由断言工厂Route Predicate Factory4. 过滤器…

【数据结构】千字深入浅出讲解队列(附原码 | 超详解)

&#x1f680;write in front&#x1f680; &#x1f4dd;个人主页&#xff1a;认真写博客的夏目浅石. &#x1f381;欢迎各位→点赞&#x1f44d; 收藏⭐️ 留言&#x1f4dd; &#x1f4e3;系列专栏&#xff1a;C语言实现数据结构 &#x1f4ac;总结&#xff1a;希望你看完…

javaweb实习实训管理系统mysql

本毕业设计基于JSP的实习实训管理系统&#xff0c;本系统能实现网上的实习实训信息管理&#xff0c;主要功能有&#xff1a;添加用户、查看用户、管理用户、添加实验室、查看实验室、管理实验室、添加课程、查看课程、管理课程、添加教学、查看教学、管理教学、添加实习、查看实…

STM32的推挽输出和开漏输出

文章目录 前言一、推挽输出二、开漏输出三、区别和适应场景总结前言 本篇文章将带大家了解STM32的推挽输出和开漏输出,并且学习这两个的区别,学习分别在什么时候使用这两个不同的输出方式。 在 STM32 微控制器中,GPIO(General Purpose Input/Output)模块是一个通用的输入…

Java 到底是值传递还是引用传递?

C 语言是很多变成语言的母胎&#xff0c;包括 Java。对于 C 语言来说&#xff0c;所有的方法参数都是通过 “值” 传递的&#xff0c;也就是说&#xff0c;传递给被调用方法的参数值存放在临时变量中&#xff0c;而不是存放在原来的变量中。这就意味着&#xff0c;被调用的方法…

项目质量管理工作 不得不重视的4大关键点

1、三大视角确保项目质量 我们需要从客户视角、SOW视角和组织视角三大视角&#xff0c;确保项目的质量。 从客户视角方面出发&#xff0c;满足客户的要求&#xff0c;如项目交付的准时性、项目质量的保证等。我们需要全力保障客户对项目质量的要求。 从SOW视角确保项目质量&…

[ 漏洞复现篇 ] Joomla未授权访问Rest API漏洞(CVE-2023-23752)

&#x1f36c; 博主介绍 &#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 _PowerShell &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【数据通信】 【通讯安全】 【web安全】【面试分析】 &#x1f389;点赞➕评论➕收藏 养成习…

Java实习生------MySQL10道面试题打卡

今日语录&#xff1a;“没有执行力&#xff0c;就没有竞争力 ”&#x1f339; 参考资料&#xff1a;图解MySQL、MySQL面试题 1、事务有哪些特性&#xff1f; 原子性&#xff1a; 一个事务中的所有操作&#xff0c;要么全部完成&#xff0c;要么全部不完成&#xff0c;不会出现…

Three.js——learn01

Three.js——learn01Three.js——learn01本地搭建文档通过parcel搭建Threejs环境1.初始化2.安装parcel设置打包位置3.设置目录结构QuickStart安装threejsindex.htmlindex.cssindex.js启动Three.js——learn01 本地搭建文档 登录GitHub搜索three.js git clone https://github…

基于数据安全的沙盘推演体系

背景 2022年由IBM和Ponemon研究所联合发布的一份全球性的研究报告&#xff0c;分析了550家遭受数据泄露事件的组织的各种成本和影响因素。根据报告&#xff0c;2022年全球数据泄露规模和平均成本均创下历史新高&#xff0c;数据泄露事件的平均成本高达435万美元&#xff0c;比2…

C语言—文件操作

1.为什么使用文件使用文件可以直接将数据存放到电脑硬盘上&#xff0c;做到数据的持久化2.什么是文件硬盘上的文件是文件但在程序中&#xff0c;我们一般谈的文件有两种&#xff1a;程序文件和数据文件&#xff08;从文件功能角度来分类的&#xff09;2.1程序文件包括源程序文件…

vue3使用vee-validate自定义表单校验,提交实现步骤

1、首先安装vee-validate&#xff08;指定版本&#xff09;&#xff0c;安装命令如下&#xff1a; npm i vee-validate4.0.32、在app.vue中写入如下内容&#xff1a;用vee-validate提供的Form组件代替form标签&#xff0c;用Field组件代替input标签&#xff0c;errors是接收校…

UnixBench----x86架构openEuler操作系统上进行性能测试

【原文链接】UnixBench----x86架构openEuler操作系统上进行性能测试 &#xff08;1&#xff09;打开github上 UnixBench 地址&#xff0c;找到发布的tag &#xff08;2&#xff09;找到tar.gz包&#xff0c;右键复制链接 比如这里是 https://github.com/kdlucas/byte-unix…