数据结构和算法之:二分法demo
package com.js.ai.modules.pointwall.testxfz;
class OrdArray{
private long[] a;
private int nElems;
public OrdArray(int max) {
a=new long[max];
nElems=0;
}
public int size(){
return nElems;
}
//插入方法
public void insert(long value){
int j;
for(j=0;j<nElems;j++){
if(a[j]>value)
break;
}
for(int k=nElems;k>j;k--){
a[k]=a[k-1];
}
a[j]=value;
nElems++;
} //删除方法
public boolean delete(long value){
int j=find(value);
if(j==nElems){
return false;
}else {
for(int k=j;k<nElems;k++){
a[k]=a[k+1];
}
nElems--;
return true;
}
} //二分查找
public int find(long searchKey){
int lowerBound=0;
int upperBound=nElems-1;
int curIn;
while(true){
curIn=(lowerBound+upperBound)/2;
if(a[curIn]==searchKey){
return curIn;
}else if(lowerBound>upperBound){
return nElems;
}else {
if(a[curIn]<searchKey){
lowerBound=curIn+1;
}else {
upperBound=curIn-1;
}
}
}
} public void display(){
for(int j=0;j<nElems;j++){
System.out.print(a[j]+" ");
}
System.out.print("");
}
}
public class OrdArrayTest {
public static void main(String[] args) {
int maxSize=100;
OrdArray arr;
arr=new OrdArray(maxSize);
arr.insert(77);
arr.insert(00);
arr.insert(11);
arr.insert(22);
arr.insert(88);
arr.insert(99);
arr.insert(33);
arr.insert(55);
arr.insert(44);
arr.insert(66);
int searchKey=55;
if(arr.find(searchKey)!=arr.size()){
System.out.println("Found:"+searchKey);
}else {
System.out.println("can not found:"+searchKey);
}
arr.display();
arr.delete(00);
arr.delete(55);
arr.delete(99);
System.out.println("\r\n===");
arr.display();
}
}
数据结构和算法之:二分法demo的更多相关文章
- java数据结构和算法学习笔记
		第一章 什么是数据结构和算法 数据结构的概述 数据结构是指 数据再计算机内存空间或磁盘空间中的组织形式 1.数据结构的特性 数据结构 优点 缺点 数组 插入快,如果知道下标可以快速存取 查找和删除慢 ... 
- 数据结构与算法 Big O 备忘录与现实
		不论今天的计算机技术变化,新技术的出现,所有都是来自数据结构与算法基础.我们需要温故而知新. 算法.架构.策略.机器学习之间的关系.在过往和技术人员交流时,很多人对算法和架构之间的关系感 ... 
- javascript数据结构与算法--散列
		一:javascript数据结构与算法--散列 一:什么是哈希表? 哈希表也叫散列表,是根据关键码值(key,value)而直接进行访问的数据结构,它是通过键码值映射到表中一个位置来访问记录的,散列 ... 
- javascript数据结构与算法---栈
		javascript数据结构与算法---栈 在上一遍博客介绍了下列表,列表是最简单的一种结构,但是如果要处理一些比较复杂的结构,列表显得太简陋了,所以我们需要某种和列表类似但是更复杂的数据结构---栈 ... 
- javascript数据结构与算法---列表
		javascript数据结构与算法---列表 前言:在日常生活中,人们经常要使用列表,比如我们有时候要去购物时,为了购物时东西要买全,我们可以在去之前,列下要买的东西,这就要用的列表了,或者我们小时候 ... 
- php数据结构与算法
		php面试题之二--数据结构和算法(高级部分) 二.数据结构和算法 1.使对象可以像数组一样进行foreach循环,要求属性必须是私有.(Iterator模式的PHP5实现,写一类实现Iterator ... 
- php面试题之二——数据结构和算法(高级部分)
		二.数据结构和算法 1.使对象可以像数组一样进行foreach循环,要求属性必须是私有.(Iterator模式的PHP5实现,写一类实现Iterator接口)(腾讯) <?php class T ... 
- php面试之数据结构和算法
		二.数据结构和算法 1.使对象可以像数组一样进行foreach循环,要求属性必须是私有.(Iterator模式的PHP5实现,写一类实现Iterator接口)(腾讯) <?php class T ... 
- 在Object-C中学习数据结构与算法之排序算法
		笔者在学习数据结构与算法时,尝试着将排序算法以动画的形式呈现出来更加方便理解记忆,本文配合Demo 在Object-C中学习数据结构与算法之排序算法阅读更佳. 目录 选择排序 冒泡排序 插入排序 快速 ... 
- Python 数据结构和算法
		阅读目录 什么是算法 算法效率衡量 算法分析 常见时间复杂度 Python内置类型性能分析 数据结构 顺序表 链表 栈 队列 双端队列 排序与搜索 冒泡排序 选择排序 插入排序 希尔排序 快速排序 归 ... 
随机推荐
- PostgreSQL基于时间点故障恢复PITR( point-in-time recovery )
			PostgreSQL在使用过程中经常会发生一些失误的操作,但往往是可以弥补的.但是如果真遇到了无法挽回的误操作,只能寄希望于有备份了. 接下来的故障恢复也是基于有备份的情况,没有备份的情况,目前还没有 ... 
- Okhttp之连接池ConnectionPool简单分析(一)
			开篇声明:由于本篇博文用到的一些观点或者结论在之前的博文中都已经分析过,所以本篇博文直接拿来用,建议读此博文的Monkey们按照下面的顺序读一下博主以下博文,以便于对此篇博文的理解: <Okht ... 
- python的if判断补充
			python的if判断补充 exit_flag = False # 标识符 if exit_flag == False: print('exit_flag == False') exit_flag = ... 
- iPhone开机键坏了如何开机
			作死 开机 [苹果手机/iphone开机键坏了怎么开机] 
- js之方向检测
			<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ... 
- 【剑指offer】输入一颗二叉树的根节点,求二叉树的深度,C++实现
			原创博文,转载请注明出处! # 题目 # 举例 下图二叉树的深度为4,最长路径为1-2-5-7. # 思路(递归) 如果一个树只有一个节点,它的深度为1: 如果根节点只有左子 ... 
- [转载][QT][SQL]sq]学习记录1_模糊搜索
			转载自:sql学习网站: http://www.w3school.com.cn/sql/index.asp 用于模糊搜索数据库的数据 语句:http://www.w3school.com.cn/sql ... 
- flask第十九篇——模板【3】
			请关注微信公众号:自动化测试实战 今天我们继续模板的知识,现在我们增加字典的复杂度,这个时候在render_template第二个参数可以传**title,以后我们会用**context代替原来的ti ... 
- Appium+python (3) 元素定位(1)
			打开问价夹下面的uiautomatorviewer: 夜神模拟器里的App后,回到uiautomatorviewer: 点击左上角的Device Screenshot,这时你的夜神模拟器页面就会显示在 ... 
- Django之tag标签和filter标签
			1.Django的tag常见的标签,可以做一些简单的功能 {%if%} 的使用主要用于做判断,还可以包含{%elif%} 这样的用法,最后要跟上{% endif %}.可以使用你的and,or,not ... 
