【题解 | 思维】三元组中心问题

三元组中心问题

注意点:

  1. 同一个位置的元素,不管以它为中心能组成多少个三元组,只记一个
  2. 不同索引位置的相同元素,算多个中心元素

常规暴力

java 复制代码
import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner in = new Scanner(System.in);
		int n = in.nextInt();
		int numbers[] = new int[n + 1];
		for (int i = 1; i < n + 1; i++) {
			numbers[i] = in.nextInt();
		}
		int ans = 0;
		int help[] = new int[n + 1];
		for (int i = 1; i < n + 1; i++) {
			for (int j = i + 1; j < n + 1; j++) {
				for (int k = j + 1; k < n + 1; k++) {
					if (numbers[i] < numbers[j] && numbers[j] < numbers[k]) {
						help[j] = 1;
					}
				}
			}
		}
		for (int j = 1; j < n + 1; j++) {
			if (help[j] != 0) {
				ans++;
			}
		}
		System.out.println(ans);
		in.close();
	}
}

Stream流

java 复制代码
import java.util.Arrays;
import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner in = new Scanner(System.in);
		int n = in.nextInt();
		int[] numbers = new int[n];
		for (int i = 0; i < n; i++) {
			numbers[i] = in.nextInt();
		}
		int ans = 0;
		for (int i = 1; i < n; i++) {
			if (numbers[i] > Arrays.stream(numbers, 0, i).min().getAsInt()
			 && numbers[i] < Arrays.stream(numbers, i, n).max().getAsInt()) {
				ans++;
			}
		}
		System.out.println(ans);
		in.close();
	}
}

对数组numbers进行遍历,从第二个元素开始,到倒数第二个元素结束(因为作为递增三元组的中心,至少需要有一个元素在它的左边和右边)。

对于每个元素,检查它是否大于它左边的所有元素中的最小值 ,并且小于它右边的所有元素中的最大值。如果满足这两个条件,那么这个元素就可能作为递增三元组的中心,计数器ans增加1。

相关推荐
Mr.Winter`1 分钟前
轨迹优化 | 微分动态规划DDP与迭代线性二次型调节器iLQR理论推导
人工智能·算法·机器人·自动驾驶·动态规划·ros·具身智能
Java程序员威哥1 分钟前
Spring Boot 3.x 云原生终极适配:GraalVM 原生镜像构建 + Serverless 生产级部署(完整实战+最优模板)
java·开发语言·spring boot·后端·云原生·serverless·maven
小魏每天都学习2 分钟前
【数据结构学习】
算法·图论
黛玉晴雯子0013 分钟前
Kubernets-Helm&发布模式(持续更新)
java·开发语言
qq_12498707533 分钟前
基于微信小程序宠物服务系统(源码+论文+部署+安装)
java·spring boot·后端·微信小程序·小程序·毕业设计·宠物
Physicist in Geophy.4 分钟前
矩阵的本质
算法·机器学习·矩阵
小龙报4 分钟前
【算法通关指南:算法基础篇 】贪心专题之简单贪心:1.最大子段和 2.纪念品分组
c语言·数据结构·c++·算法·ios·贪心算法·动态规划
AlenTech5 分钟前
148. 排序链表 - 力扣(LeetCode)
数据结构·leetcode·链表
一嘴一个橘子6 分钟前
springMvc 快速体验
java
毕设源码-朱学姐8 分钟前
【开题答辩全过程】以 基于SSM框架的药店管理系统的设计与开发为例,包含答辩的问题和答案
java