判断一个数是否存在于一个非递减的有序数列中 算法(Ordered Search Problem)

1. Description

Given a list of 

n numbers in non-decreasing order A={a1,a2,,an} such that a1a2an and a number x, the objective is to determine if x is present in the list A

2. Algorithm

Algorithm 1.
  • Linear Search Algorithm
    • Iterate through n numbers to find the x.
Algorithm 2.
  • Binary Search Algorithm.
3. Time complexity

Algorithm 1.

O(n)


Algorithm 2.

O(logn)

4. Implementation

Algorithm 1.

public class LinearSearch {public static void Result(int Seq[],int Len,int x){for(int i=0;i<Len;i++){if(x==Seq[i]){System.out.println(x+" is present at seq["+i+"]");break;}else if(x!=Seq[i]&&i==Len-1){System.out.println(x+" is not present in seq");}}}public static void main(String[] args){int Seq[]={4,33,40,44,45,45,55,60,99};int Len=Seq.length;Result(Seq,Len,55);	Result(Seq,Len,70);}
}
Result of Algorithm1:



Algorithm 2-Implementation1

public class BinarySearch1 {public static void BinarySearch(int Seq[],int x,int left,int right){		int mid=(left+right)/2;if(left==right-1&&x!=Seq[left]&&x!=Seq[right]) //如果只剩两个数,两个数都不是x,那么x不在数组Seq中{System.out.println(x+" is not present in Seq");}else if(x==Seq[mid]){System.out.println(x+" is present at Seq["+mid+"]");}else if(x>Seq[mid]){	System.out.println(x+" is between seq["+mid+"] and Seq["+right+"]");left=mid;BinarySearch(Seq,x,left,right);}else if(x<Seq[mid]){System.out.println(x+" is between seq["+left+"] and Seq["+mid+"]");right=mid;BinarySearch(Seq,x,left,right);}}public static void main(String args[]){int Seq[]={1,2,3,3,8,9,11,56,89};int left=0, right=Seq.length-1;System.out.println("Test whether 56 is present in seq:");BinarySearch(Seq,56,left,right);System.out.println("Test whether 7 is present in seq:");BinarySearch(Seq,7,left,right);}
}

Algorithm 2-Implementation2

public class BinarySearch2 {public static void BinarySearch(int Seq[],int x){int left=0;int right=Seq.length-1;int mid=(left+right)/2;while(true){if(x==Seq[mid]){System.out.println(x+" is present at Seq["+mid+"]");break;}else if(x>Seq[mid]){System.out.println(x+" is between seq["+mid+"] and Seq["  +right+"]");  left=mid+1;if(left>=right){System.out.println(x+" is not in seq");break;}mid=(left+right)/2;}else if(x<Seq[mid]){System.out.println(x+" is between seq["+left+"] and Seq["  +mid+"]");  right=mid-1; if(left>=right){System.out.println(x+" is not in seq");break;}mid=(left+right)/2;}}}public static void main(String[] args){int Seq[]={4,33,40,44,45,45,55,60,99};   System.out.println("Test whether 56 is present in seq:");  BinarySearch(Seq,55);  System.out.println("Test whether 7 is present in seq:");  BinarySearch(Seq,70);  }
}
Result of Both implementation1 and implementation2:




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

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

相关文章

(4.12)全面解析-SQL事务+隔离级别+阻塞+死锁

30分钟全面解析-SQL事务隔离级别阻塞死锁 转自&#xff1a;https://blog.csdn.net/slowlifes/article/details/52752735 2016年10月07日 23:17:46 阅读数&#xff1a;1097阅读目录 概述&#xff1a;一、事务二、锁三、阻塞四、隔离级别五.死锁以前总是追求新东西&#xff0c;发…

抽屉原理

“抽屉原理”最先是由19世纪的德国数学家迪里赫莱&#xff08;Dirichlet&#xff09;运用于解决数学问题的&#xff0c;所以又称“迪里赫莱原理”&#xff0c;也有称“鸽巢原理”的。这个原理可以简单地叙述为“把10个苹果&#xff0c;任意分放在9个抽屉里&#xff0c;则至少有…

jdbc之连接Oracle的基本步骤

1 // 1.加载驱动程序2 Class.forName("oracle.jdbc.driver.OracleDriver");3 // 2.获取数据库连接4 Connection conn DriverManager.getConnection("jdbc:oracle:thin:localhost:1521:orcl", "j0408", "1");5 // 3.构建SQL语句6 Stri…

[jzoj 5775]【NOIP2008模拟】农夫约的假期 (前缀和+递推)

传送门 Description 在某国有一个叫农夫约的人&#xff0c;他养了很多羊&#xff0c;其中有两头名叫mm和hh&#xff0c;他们的歌声十分好听&#xff0c;被当地人称为“魔音” 农夫约也有自己的假期呀&#xff01;他要去海边度假&#xff0c;然而mm和hh不能离开他。没办法&#…

mac启动mysql,apache,php

在用php编写网站之前&#xff0c;先要启动之前搭建好的环境。 1.启动mysql &#xff08;1&#xff09;在system preference的最底部有mysql控制图标&#xff1a; &#xff08;2&#xff09;点击mysql图标&#xff0c;启动mysql&#xff1a; 2.启动apache&#xff1a; 在term…

如何在命令长度受限的情况下成功get到webshell(函数参数受限突破、mysql的骚操作)...

0x01 问题提出 还记得上篇文章记一次拿webshell踩过的坑(如何用PHP编写一个不包含数字和字母的后门)&#xff0c;我们讲到了一些PHP的一些如何巧妙地绕过数字和字母受限的技巧&#xff0c;今天我要给大家分享的是如何在命令长度受限的情况下成功get到webshell&#xff0c;以及关…

iOS开发造轮子 | 通用占位图

https://www.jianshu.com/p/beca3ac24031 实际运用场景&#xff1a; 没网时的提示view&#xff0c;tableView或collectionView没内容时的展示view&#xff0c;以及其它特殊情况时展示的特定view。如&#xff1a; 常见的几种情况我的目标&#xff1a; 对以上几种情况的展示view做…

java 计算26个字母在一段文本中出现的频率(保留小数点后4位)

public class FrequencyCalculator {public static void main(String[] args){//定义需要计算字母出现频率的文本String text"some off#acebooksea3rl255 yinvestorssoldofftheirstockatthefirs" "tchancetheygotbutceomarkzuckerbergishangingontohissharesfor…

Maven_生产环境下开发对Maven的需求

目前技术开发时存在的问题&#xff1a; 一个项目就是一个工程 如果一个项目非常庞大&#xff0c;就不适合继续使用package来划分模块。最好是每一个模块对应一个工程&#xff0c;利于分工协作。 借助Maven就可以将一个项目拆分多个工程。 项目中需要的jar包必须手动复制粘贴到W…

string赋值-单引号和双引号的区别(php)

在赋予一个string值的时候&#xff0c;可以用单引号或者双引号。 1.单引号和双引号的区别&#xff1a; 单引号&#xff1a;不会翻译变量。 双引号&#xff1a;会翻译变量&#xff0c;会将变量替换为之前赋予变量的值。 例子&#xff1a; &#xff08;1&#xff09;单引号&a…

Web项目开发流程 PC端

Web项目开发流程 PC端 转自 https://www.cnblogs.com/mdengcc/p/6475733.html一直再做前端&#xff0c;突然想到如果有一天领导让自己独立承担一个web 项目的话是否有足够的能力去接这个任务&#xff0c;要学会自己去搭建一些基础的工具信息。所有的这一切在心里都要有个大致的…

Hibernate常用的Java数据类型映射到mysql和Oracle

研究了常用的Java基本数据类型在mysql和oracle数据库的映射类型。这里使用的是包装类型做研究&#xff0c;一般在hibernate声明的时候最好不要用基本类型&#xff0c;因为数据库中的null空数据有可能映射为基本类型的时候会报错&#xff0c;但是映射到包装类型的时候值为null&a…

Spring Cloud 之 Feign 使用HTTP请求远程服务

Feign是从Netflix中分离出来的轻量级项目&#xff0c;能够在类接口上添加注释&#xff0c;成为一个REST API 客户端&#xff0c;Feign默认集成了Ribbon。 Feign中对 Hystrix 有依赖关系。Feign只是一个便利的rest框架&#xff0c;简化调用&#xff0c;最后还是通过ribbon在注册…

UI控件之UISlider

一、创建 UISlider *slider [[UISlider alloc] initWithFrame:CGRectMake(0, 200, self.view.frame.size.width-100, 50)]; 二、设置最大最小值 slider.minimumValue 0; slider.maximumValue 1; 三、改变圆形前面和后面的颜色 slider.minimumTrackTintColor [UIColor orang…

Front End Accessibility Development Guide

Header Carefully write heading(h1,h2,h3) for screen reader. Alternative Image Provide alt text for both essential and functional images. Provide empty alt text (alt””) for decorative images. Don’t repeat the alt text of an image in the adjacent text. De…

详细的Windows下安装 binwalk

1. https://github.com/ReFirmLabs/binwalk到这里下载binwalk&#xff0c;下载后解压。 2. 找到下载后的文件夹&#xff0c; 在这里要进行安装步骤&#xff0c;一边按着shift&#xff0c;一边按着鼠标右键&#xff0c;点击在此处打开命令窗口。 输入python setup.py install 安…

各大浏览器清除缓存(cache)详细步骤

1. Firefox 1.1 选择“Options”&#xff1a; 1.2 选择“Advanced”->“Network”->“Cached Web Content”&#xff0c;点击“Clear Now”&#xff1a; 2. Chrome 2.1 选择“Settings”&#xff1a; 2.2 点击页面底部“Show advanced settings”&#xff1a; 2.3 选择…

python部分 + 数据库 + 网络编程

PS:附上我的博客地址&#xff0c;答案中略的部分我的博客都有&#xff0c;直接原标题搜索即可。https://www.cnblogs.com/Roc-Atlantis/第一部分 Python基础篇&#xff08;80题&#xff09;为什么学习Python&#xff1f;Omit通过什么途径学习的Python&#xff1f;OmitPython和J…

使用 angular directive 和 json 数据的 D3 带标签 donut chart示例

利用angular resource加载priorityData.json中的json数据&#xff0c;结合D3画出甜甜圈图。运行index.html结果如图所示&#xff1a; priorityData.json中json数据如下&#xff1a; { "priority":{ "Blocker":12,"Critical":18,"Major&qu…

第一个express app 详细步骤

1. 全局安装node.js&#xff08;请参考网上教程&#xff09;。 如何判断是否全局安装成功&#xff1f;打开命令行终端&#xff0c;进入任意文件夹&#xff0c;输入node&#xff0c;不报错。 2. 安装express 2.1 创建app文件夹。并在此文件夹下创建文件package.json如下&#…