牛客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;
}

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

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

相关文章

小程序组件间传值

1、属性绑定&#xff08;Props&#xff09;: 父组件通过在子组件标签上设置属性的方式向子组件传值。 子组件通过properties定义接收的属性 父组件&#xff1a; wxml <child-component title"{{parentData}}"></child-component>子组件&#xff1a; js p…

可观测性监控

1 目的 常见的监控&#xff0c;主要是以收集数据以识别异常系统效应为主&#xff0c;多是单个服务&#xff0c;相互独立的状态。 可观测性&#xff0c;希望调查异常系统效应的根本原因&#xff0c;能够把多个服务、中间件、容器等串联起来&#xff0c;同时柔和metrics、log、…

前端怎么用 EventSource? EventSource怎么配置请求头及加参数? EventSourcePolyfill使用方法

EventSource EventSource 接口是 web 内容与服务器发送事件通信的接口。 一个 EventSource 实例会对 HTTP 服务器开启一个持久化的连接&#xff0c;以 text/event-stream 格式发送事件&#xff0c;此连接会一直保持开启直到通过调用 EventSource.close() 关闭。 EventSource…

常见的推荐系统框架

1&#xff09;Microsoft Recommender&#xff1a; 该框架由微软开发&#xff0c;可以免费使用&#xff0c;主要提供了包括一般功能&#xff08;Common Utilities&#xff09;、大数据功能&#xff08;Dataset Utilities&#xff09;、评价功能&#xff08;Evaluation Utilitie…

将本地docker镜像以压缩包格式保存至其他路径、从本地的镜像压缩包中加载docker镜像

保存本地Docker镜像为压缩包至其他路径 你可以使用 docker save 命令结合输出重定向&#xff08; -o 选项&#xff09;来将本地Docker镜像保存为一个压缩包&#xff08;通常是tar格式&#xff09;并直接保存到指定的路径。以下是一个示例命令&#xff1a; docker save -o /pa…

c++ - 在循环中使用迭代器删除 unordered_set 中的元素

标签 c unordered-set 请考虑以下代码: Class MyClass 为自定义类:class MyClass { public:MyClass(int v) : Val(v) {}int Val; };然后下面的代码将在调用 it T.erase(it); 之后在循环中导致 Debug Assertion Failed: unordered_set<MyClass*> T; unordered_set<…

vue3.0(六) toRef,toValue,toRefs和toRow,markRaw

文章目录 toReftoValuetoRefstoRowmarkRawtoRef和toRefs的区别toRaw 和markRaw的用处 toRef toRef 函数可以将一个响应式对象的属性转换为一个独立的 ref 对象。返回的是一个指向源对象属性的 ref 引用&#xff0c;任何对该引用的修改都会同步到源对象属性上。使用 toRef 时需…

C#中的继承、接口和多态性

继承&#xff08;Inheritance&#xff09; 在C#中&#xff0c;继承允许我们创建一个新的类&#xff08;称为子类或派生类&#xff09;&#xff0c;该类从另一个已存在的类&#xff08;称为父类或基类&#xff09;中继承方法和属性。子类可以添加新的方法和属性&#xff0c;或者…

2024年最新趋势跨境电商平台开发需了解的新技术

随着数字化技术的不断演进和全球市场的日益融合&#xff0c;跨境电商平台开发将面临前所未有的挑战和机遇。为了更好地适应并引领这一发展&#xff0c;开发者需要密切关注2024年最新的技术趋势&#xff0c;以确保他们的平台能够在竞争激烈的市场中脱颖而出。本文将对跨境电商平…

HTML/CSS2

1.前置说明 HTML/CSS1 2.img元素 格式&#xff1a; <img src"图片地址" alt"占位文字" width"图片宽度" height"图片高度">其中alt是当图片加载失败时显示的文字 而且不同内核的浏览器显示出来的占位文字的效果也是不尽相同…

网安面经之文件上传漏洞

一、文件上传漏洞 1、文件上传漏洞的原理&#xff1f;危害&#xff1f;修复&#xff1f; 原理&#xff1a;⽂件上传漏洞是发⽣在有上传功能的应⽤中&#xff0c;如果应⽤程序对⽤户上传的⽂件没有控制或者存在缺陷&#xff0c;攻击者可以利⽤应⽤上传功能存在的缺陷&#xff…

从文本日志到图形日志 图形化编程桌面产品的突破

在一个宽敞明亮的会议室里&#xff0c;阳光透过落地窗洒在会议桌上。卧龙和凤雏相对而坐&#xff0c;他们的面前摆放着一些关于图形化编程桌面产品的资料和测试报告。会议室里的气氛紧张而热烈&#xff0c;团队成员们围坐在一起&#xff0c;专注地倾听着卧龙和凤雏的讨论。 卧龙…

单位学校FM调频电台直放站系统

随着教育技术的不断发展&#xff0c;校园广播系统的建设已成为现代学校必不可少的一部分。作为传统有线广播的有效补充&#xff0c;基于无线电信号传输的 FM 调频电台在学校的使用日益广泛&#xff0c;尤其是在紧急通知、日常信息传播及教学辅助等方面发挥着重要作用。为了增强…

韩顺平0基础学Java——第9天

p169-201 数组&#xff08;第六章&#xff09; 数组扩容 此时原来的数组arr被销毁。 牛蛙&#xff1a; 最后再加一句 SYstem。out。println&#xff08;“是否添加&#xff1f;”&#xff09;&#xff1b; char key myscanner。netx&#xff08;&#xff09;。charAT&…

【Python超详细的学习笔记】Python超详细的学习笔记,涉及多个领域,是个很不错的笔记

获取笔记链接 Python超详细的学习笔记 一&#xff0c;逆向加密模块 1&#xff0c;Python中运行JS代码 1.1 解决中文乱码或者报错问题 import subprocess from functools import partial subprocess.Popen partial(subprocess.Popen, encodingutf-8) import execjs1.2 常用…

Agent AI智能体:未来社会的角色、发展路径与挑战

目录 引言 一、Agent AI智能体的发展路径 1. 技术进步与智能化水平提升 2. 应用场景拓展与普及 二、Agent AI智能体在未来社会中的角色 1. 提高生产效率与生活品质 2. 促进社会进步与发展 三、Agent AI智能体可能带来的挑战 1. 隐私与安全问题 2. 就业与社会结构变革 …

04_led_water_flow_v0 流水灯

04_led_water_flow_v0 流水灯和跑马灯都是一种常见的LED灯效&#xff0c;它们在灯光的变化方式上有所不同。 流水灯是一种灯效模式&#xff0c;LED灯在一定的时间间隔内依次点亮或熄灭&#xff0c;形成像水流一样的效果。而跑马灯则是LED灯在一定的时间间隔内依次从左向右或从…

6-8 十进制转换二进制(递归)

分数 10 作者 C课程组 单位 浙江大学 本题要求实现一个函数&#xff0c;将非负整数n转换为二进制后输出。 函数接口定义&#xff1a; void dectobin( int n );函数dectobin应在一行中打印出二进制的n。建议用递归实现。 裁判测试程序样例&#xff1a; #include <stdio…

WordPress插件Plus WebP,可将jpg、png、bmp、gif图片转为WebP

现在很多浏览器和CDN都支持WebP格式的图片了&#xff0c;不过我们以前的WordPress网站使用的图片都是jpg、png、bmp、gif&#xff0c;那么应该如何将它们转换为WebP格式的图片呢&#xff1f;推荐安装这款Plus WebP插件&#xff0c;可以将上传到媒体库的图片转为WebP格式图片&am…

HIVE调优MapJoin

HIVE调优MapJoin 目录 HIVE调优MapJoin 1.mapjoin &#xff08;1.2以后自动默认启动mapjoin&#xff09; 2.创建表格 3.查询建表 4.通过 explain 展示执行计划 5.Map JOIN 相关设置&#xff1a; 1.mapjoin &#xff08;1.2以后自动默认启动mapjoin&#xff09;…