NO6---蓝桥杯JAVA---连号区间数

2023-11-10 10:30
文章标签 java 蓝桥 区间 连号 no6

本文主要是介绍NO6---蓝桥杯JAVA---连号区间数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

小明这些天一直在思考这样一个奇怪而有趣的问题:

在 1∼N的某个排列中有多少个连号区间呢?

这里所说的连号区间的定义是:

如果区间 [L,R]里的所有元素(即此排列的第 L个到第 R个元素)递增排序后能得到一个长度为 R−L+1的“连续”数列,则称这个区间连号区间。

当 N 很小的时候,小明可以很快地算出答案,但是当 N 变大的时候,问题就不是那么简单了,现在小明需要你的帮助。

输入格式

第一行是一个正整数 N,表示排列的规模。

第二行是 N个不同的数字 Pi,表示这 N 个数字的某一排列。

输出格式

输出一个整数,表示不同连号区间的数目。

数据范围

1≤N≤10000
1≤Pi≤N

输入样例1:
4
3 2 4 1
输出样例1:
7

本题主要考优化算法
其实正常思路 挨个在不同区间内比大小 找最值 与区间大小比较  但是它不能全部运行  在N=10003时出错
import java.util.Scanner;public class Main {public static Long N;public static int ans[]=new int[10003];public static Long count=(long) 0;public static void main(String[] args) {Scanner sc=new Scanner(System.in);N=sc.nextLong();sc.nextLine();for(int i=0;i<N;i++) {int t=sc.nextInt();ans[i]=t;}sc.close();for(int i=0;i<N;i++) {for(int j=i;j<N;j++) {int min=ans[i];int max=ans[i];for(int k=i+1;k<=j;k++) {if(ans[k]<min)min=ans[k];if(ans[k]>max)max=ans[k];}int ee=j-i;if(ee==(max-min))count++;}}System.out.println(count);}}
所以我上网找了一下JAVA的专属语句,以及可以把输入的数组变成字符串,减少消耗,方便分区
bufferedreader: 从字符输入流读取文本,缓冲字符,以提供字符,数组和行的高效读取 ;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Scanner;public class Main {static BufferedReader br = new BufferedReader(new InputStreamReader(System.in));public static int arr[]=new int[10003];public static int res=0;public static void main(String[] args) throws Exception {int n = Integer.parseInt(br.readLine());String[] str = br.readLine().split(" ");for (int i=1; i<=n; i++) {arr[i] = Integer.parseInt(str[i-1]); //设定区间下标从1开始,所以i-1}for (int i=1; i<=n; i++) {int minv = Integer.MAX_VALUE;int maxv = Integer.MIN_VALUE;for (int j=i; j<=n; j++) {minv = Math.min(minv,arr[j]);maxv = Math.max(maxv,arr[j]);if (maxv - minv == j - i) {res ++;}}}System.out.println(res);}}

这篇关于NO6---蓝桥杯JAVA---连号区间数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/382069

相关文章

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

浅析Spring如何控制Bean的加载顺序

《浅析Spring如何控制Bean的加载顺序》在大多数情况下,我们不需要手动控制Bean的加载顺序,因为Spring的IoC容器足够智能,但在某些特殊场景下,这种隐式的依赖关系可能不存在,下面我们就来... 目录核心原则:依赖驱动加载手动控制 Bean 加载顺序的方法方法 1:使用@DependsOn(最直

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件