但是,在通过移动数组的上升周期中找到指定元素

但是,在通过移动数组的上升周期中找到指定元素

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

该阵列是按升序排列,通过循环数组后动。肯定是有左半或半或升序的一部分。

代码:

public class SearchRotateArray {
	public static int search(int a[], int l, int u, int x) {
		while(l<=u){
			int m = (l+u)/2;
			if(x==a[m]){
				return m;
			}else if(a[l]<=a[m]){ //左半部分升序排列
				if(x>a[m]){
					l=m+1;
				}else if(x>=a[l]){
					u=m-1;
				}else{// x<a[l]
					l=m+1;
				}
			}else if(a[l]>a[m]){ //右半部分升序
				if(x>a[u]){
					u=m-1;
				}else if(x>=a[m]){
					l=m+1;
				}else{ //x<a[m]
					u=m-1;
				}
			}
		}
		return -1;
	}
	
	
	public static void main(String[] args){
		int a[] = {15,16 ,19, 20, 25, 1, 3, 4, 5, 7, 10, 14};
		System.out.println(search(a, 0, a.length - 1, 5));
	}
}

结果:

8

版权声明:本文博客原创文章,博客,未经同意,不得转载。

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

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

(0)
上一篇 2022年1月7日 下午5:00
下一篇 2022年1月7日 下午5:00


相关推荐

  • QStringList 使用

    QStringList 使用创建QStringList获取QStringList里面的元素QStringListstrList=item.split(‘#’);QStringstr1=strList.at(0);QStringstr2=strList.at(1);

    2022年4月27日
    70
  • layui弹出层html,layer弹出层「建议收藏」

    layui弹出层html,layer弹出层「建议收藏」layer弹出层,怎么只让他弹出一次.在线等我昨天用这个插件的时候也有这个问题,弹出内容大了就居不了中。这是组件不完美的地方,他设置了top和left值,而且是固定的。这种弹出层都是绝对定位的所以没办法用margin:auto0神马的居中。解决方案主要两种:1.修改在浏览器里面调试模式。jquerylayer怎么弹出指定的html内元素一个基本的弹出层应该满足以下需CSS布局HTML小编…

    2022年7月13日
    17
  • 【贪玩巴斯】C/C++文件IO流操作的 seekp和seekg详解「建议收藏」

    【贪玩巴斯】C/C++文件IO流操作的 seekp和seekg详解「建议收藏」文件流对象有两个成员函数,分别是seekp和seekg。它们可以用于将读写位置移动到文件中的任何字节。一、如何来记这几个函数呢seek是寻找寻求的意思2.tell是告诉告知的意思那p即put放和输出的意思,在这里是保存到文件那g即get是获取,读入的意思,在这里是从文件读取所以seekp可用于将信息put(放入写入)到文件中2.seekg则可用于从文件中get(获取)信息。tellg()函数不需要带参数,它返回当前定位指针的位置,也代

    2022年6月1日
    44
  • SPSS方差分析应该如何进行

    SPSS方差分析应该如何进行以前 我们在学统计学的时候 做方差分析的话 常常会用到 spss 这款软件 后来 在工作上 很多实验数据的分析 也还是会用到 spss 用它来分析比较实验数据之间有无显著差异 对此 很多刚接触该软件的用户就问到如何用 spss 做方差分析 所以 本文来讲解用 spss 做方差分析的方法步骤 帮助大家分析结果的数据差异 从而提高实验的有效性 用 spss 做方差分析教程 1 首先 我们打开 spss 软件 在软件的左下方点击切换到 变量视图 的操作界面 2 因为要用 spss 做方差分析 故此

    2026年3月26日
    2
  • Pycharm界面设置

    Pycharm界面设置1 修改主题等 file Settings Appearance amp Behavior Appearance Theme 修改主题 Name 修改主题字体 Size 修改主题字号 2 修改代码 字格式 file Settings Editor Font Font 修改字体 Size 修改字号 LineSpacing 修改 间距 3 修改解释器解释器的作 运 件 Pycharm 没有内置的 Python 解释器 需要加载

    2026年3月27日
    2
  • 可更新resultset

    可更新resultset

    2021年8月12日
    56

发表回复

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

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