牛客NC404 最接近的K个元素【中等 二分查找+双指针 Java/Go/PHP】

2024-05-12 19:20

本文主要是介绍牛客NC404 最接近的K个元素【中等 二分查找+双指针 Java/Go/PHP】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目

在这里插入图片描述
题目链接:
https://www.nowcoder.com/practice/b4d7edc45759453e9bc8ab71f0888e0f

知识点

	二分查找;找到第一个大于等于x的数的位置idx;然后从idx开始往两边扩展

Java代码

import java.util.*;public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可*** @param nums int整型ArrayList* @param k int整型* @param x int整型* @return int整型ArrayList*/public ArrayList<Integer> closestElement (ArrayList<Integer> nums, int k,int x) {//二分+双指针int n = nums.size();int right = firstGt(nums, x);int left = right - 1;ArrayList<Integer> ans = new ArrayList<>();LinkedList<Integer> ll = new LinkedList<>();if (right == 0) {for (int i = 0; i < k ; i++) {ll.add(nums.get(i));}} else if (right == n - 1) {for (int i = n - 1 - k; i < n ; i++) {ll.add(nums.get(i));}} else {while (left >= 0 || right < n) {int diffleft = -1;int diffright = -1;if (left >= 0) {diffleft = x - nums.get(left);}if (right < n) {diffright = nums.get(right) - x;}if (diffleft != -1 && diffright != -1) {if (diffleft <= diffright) {ll.addFirst(nums.get(left--));} else {ll.addLast(nums.get(right++));}} else if (diffleft != -1) {ll.addFirst(nums.get(left--));} else if (diffright != -1) {ll.addLast(nums.get(right++));}if (ll.size() == k)break;}}return new ArrayList<>(ll);}//找到大于等于x的下标位置public int firstGt(ArrayList<Integer> nums, int x) {int n = nums.size();int left = 0;int right = n;while (left < right) {int m = left + (right - left) / 2;if (nums.get(m) > x) {right = m - 1;} else if (nums.get(m) < x) {left = m + 1;} else {return m;}}return left;}
}

Go代码

package main//import "fmt"/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可*** @param nums int整型一维数组* @param k int整型* @param x int整型* @return int整型一维数组*/
func closestElement(nums []int, k int, x int) []int {//二分+双指针n := len(nums)right := firstGt(nums, x)arrleft := []int{}arrright := []int{}ans := []int{}if right == 0 {for i := 0; i < k; i++ {ans = append(ans, nums[i])}} else if right == n-1 {for i := n - 1 - k; i < n; i++ {ans = append(ans, nums[i])}} else {left := right - 1cnt := 0for left >= 0 || right < n {diffleft := -1diffright := -1if left >= 0 {diffleft = x - nums[left]}if right < n {diffright = nums[right] - x}if diffleft != -1 && diffright != -1 {if diffleft <= diffright {arrleft = append(arrleft, nums[left])left--} else {arrright = append(arrright, nums[right])right++}} else if diffleft != -1 {arrleft = append(arrleft, nums[left])left--} else if diffright != -1 {arrright = append(arrright, nums[right])right++}cnt++if cnt == k {for i := len(arrleft) - 1; i >= 0; i-- {ans = append(ans, arrleft[i])}for i := 0; i < len(arrright); i++ {ans = append(ans, arrright[i])}break}}}return ans
}//找到大等于x的位置
func firstGt(nums []int, x int) int {n := len(nums)left := 0right := n - 1for left < right {m := left + (right-left)/2if nums[m] > x {right = m - 1} else if nums[m] < x {left = m + 1} else {return m}}return left
}

PHP代码

<?php/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param nums int整型一维数组 * @param k int整型 * @param x int整型 * @return int整型一维数组*/
function closestElement( $nums ,  $k ,  $x )
{// 二分+双指针$n = count($nums);$right = firstGt($nums,$x);$ans = [];$arrleft=[];$arrright =[];if($right ==0 ){for($i=0;$i<$k;$i++){$ans[$i] = $nums[$i];}}else if($right ==$n-1){for($i=$n-1-$k;$i>=0;$i++){$ans[count($ans)] = $nums[$i];}}else {$left = $right-1;$cnt =0;while ($left>=0 || $right < $n){$diffleft=-1;$diffright =-1;if($left>=0) {$diffleft = $x-$nums[$left];}if($right<$n){$diffright = $nums[$right]-$x;}if($diffleft!=-1 && $diffright!=-1){if($diffleft<=$diffright){$arrleft[count($arrleft)] = $nums[$left--];}else{$arrright[count($arrright)] = $nums[$right++];}}else if($diffleft!=-1){$arrleft[count($arrleft)] = $nums[$left--];}else if($diffright!=-1){$arrright[count($arrright)] = $nums[$right++];}$cnt++;if($cnt==$k){for($i=count($arrleft)-1;$i>=0;$i--){$ans[count($ans)] = $arrleft[$i];}for($i=0;$i<count($arrright);$i++){$ans[count($ans)] = $arrright[$i];}break;}}}return $ans;
}//找到大于等于x的位置
function firstGt($nums,$x){$n = count($nums);$left =0;$right = $n;while ($left<$right){$m = $left+(($right-$left)>> 1);if($nums[$m] > $x){$right = $m-1;}else if($nums[$m] < $x){$left = $m+1;}else{return $m;}}return $left;
}

这篇关于牛客NC404 最接近的K个元素【中等 二分查找+双指针 Java/Go/PHP】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

Go标准库常见错误分析和解决办法

《Go标准库常见错误分析和解决办法》Go语言的标准库为开发者提供了丰富且高效的工具,涵盖了从网络编程到文件操作等各个方面,然而,标准库虽好,使用不当却可能适得其反,正所谓工欲善其事,必先利其器,本文将... 目录1. 使用了错误的time.Duration2. time.After导致的内存泄漏3. jsO

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

Java中的String.valueOf()和toString()方法区别小结

《Java中的String.valueOf()和toString()方法区别小结》字符串操作是开发者日常编程任务中不可或缺的一部分,转换为字符串是一种常见需求,其中最常见的就是String.value... 目录String.valueOf()方法方法定义方法实现使用示例使用场景toString()方法方法

Java中List的contains()方法的使用小结

《Java中List的contains()方法的使用小结》List的contains()方法用于检查列表中是否包含指定的元素,借助equals()方法进行判断,下面就来介绍Java中List的c... 目录详细展开1. 方法签名2. 工作原理3. 使用示例4. 注意事项总结结论:List 的 contain

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("