java二分法排序算法_Java中使用二分法排序

java二分法排序算法_Java中使用二分法排序在数据结构中学习过关于二分法排序的算法 但都是基于 C 语言或者 C 使用指针的方法 自己因为要在项目中使用到此算法 才开始将原有的程序改写为 Java 语言的 具体的说明如下 1 二分法查找插入位置如果 R i 2 后移虽然我们很清楚的知道 我们需要后移那些排序码大于 R i 的记录 但难免会问自己这样几个问题 其实它相当于需要移动从 i 1 到左指针的记录 3 插入由 1 中得到的左指针其实就是元素要插入的位置

在数据结构中学习过关于二分法排序的算法,但都是基于C语言或者C++使用指针的方法,自己因为要在项目中使用到此算法,才开始将原有的程序改写为Java语言的。具体的说明如下:

1、二分法查找插入位置

如果R[i]

2、后移

虽然我们很清楚的知道,我们需要后移那些排序码大于R[i]的记录,但难免会问自己这样几个问题。其实它相当于需要移动从i-1到左指针的记录。

3、插入

由1中得到的左指针其实就是元素要插入的位置。

4、具体的算法

public void TwoInsertSort( int[] data ) {

int left,right,num;

int middle,j;

for( int i = 1; i < data.length; i++ ) {

// 准备

left = 0;

right = i-1;

num = data[i];

// 二分法查找插入位置

while( right >= left ) {

// 指向已排序好的中间位置

middle = ( left + right ) / 2;

if( num < data[middle] )

right = middle-1; // 插入的元素在右区间

else

left = middle+1; // 插入的元素在左区间

}

// 后移排序码大于R[i]的记录

for( j = i-1; j >= left; j– ) {

data[j+1] = data[j];

}

// 插入

data[left] = num;

}

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/220619.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月17日 下午8:02
下一篇 2026年3月17日 下午8:03


相关推荐

  • mpc hc设置_mpc是指什么

    mpc hc设置_mpc是指什么MPC-HC播放器设置启动 MPC-HC ,先设置语言:(最新版本会自动选择对应的系统语言)View-Language-Chinese=>界面变为中文进 视图-选项:播放器:建议勾选「保存设置至.ini文件中」格式:建议勾选全部视频类格式,其中 QuickTime 建议采用「DirectShow」滤镜(双击右侧,在下拉框中即可选择),播放性能会

    2025年11月14日
    4
  • java基础编程入门教程,2022最新

    java基础编程入门教程,2022最新Java学习到什么程度可以找第一份工作自己买了本Java从入门到精通。以为可以很快地学完,非CS专业。现在我想说所有系列的从入门到精通都是垃圾,一年多来,我每天白天看视频,晚上敲代码到凌晨,我是一个很倔的人,我认为天下没有任何东西是人类学不会的,所以我就付出高三一样的时间去学习。为你解读Java三大框架其实作为Java初学者除了简单的学习框架本身,还需要思考更多的东西,比如有框架和没有框架到底给你带来了什么?用Struts,要充分的理解MVC思想,用Hibernate,要明白什么是持久化,什么是OR/m

    2022年7月9日
    23
  • 机器学习之KNN最邻近分类算法[通俗易懂]

    机器学习之KNN最邻近分类算法[通俗易懂]KNN算法简介KNN(K-NearestNeighbor)最邻近分类算法是数据挖掘分类(classification)技术中最简单的算法之一,其指导思想是”近朱者赤,近墨者黑“,即由你的邻居来推断出你的类别。KNN最邻近分类算法的实现原理:为了判断未知样本的类别,以所有已知类别的样本作为参照,计算未知样本与所有已知样本的距离,从中选取与未知样本距离最近的K个已知样本,根据少数服从多数…

    2022年4月27日
    52
  • 288÷4×7解决什么问题_ubuntu无法获取dpkg前端锁

    288÷4×7解决什么问题_ubuntu无法获取dpkg前端锁使用apt安装时报错:E:Couldnotgetlock/var/lib/dpkg/lock-frontend-open(11:Resourcetemporarilyunavailable)E:Unabletoacquirethedpkgfrontendlock(/var/lib/dpkg/lock-frontend),isanotherprocessusingit?解决方案:方案一:sudokillallaptapt-get如果提示没有

    2022年10月7日
    2
  • ASP.NET 页面中的 ValidateRequest属性

    ASP.NET 页面中的 ValidateRequest属性ValidateRequest指示是否应发生请求验证。如果为true,请求验证将根据具有潜在危险的值的硬编码列表检查所有输入数据。如果出现匹配情况,将引发HttpRequestValidationException异常。默认值为true。该功能在计算机配置文件(Machine.config)中启用。可以在应用程序配置文件(Web.config)中或在页上将该属性设置为false来禁用该功能。注意:该功能有助于减少对简单页或ASP.NET应用程序进行跨站点脚本攻击的

    2025年7月17日
    7
  • mongodb 唯一索引 性能_什么是唯一索引

    mongodb 唯一索引 性能_什么是唯一索引MongoDB支持的索引种类很多,诸如单键索引,复合索引,多键索引,TTL索引,文本索引,空间地理索引等。同时索引的属性可以具有唯一性,即唯一索引。唯一索引用于确保索引字段不存储重复的值,即强制索引字段的唯一性。缺省情况下,MongoDB的_id字段在创建集合的时候会自动创建一个唯一索引。本文主要描述唯一索引的用法。

    2026年1月31日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号