全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Java使用分治算法实现排序数索引功能示例【二分搜索】

本文实例讲述了Java使用分治算法实现排序数索引功能。分享给大家供大家参考,具体如下:

/**
 * Find the first q and return the index
 * First method is brutal force
 * Second may
 * be Divid and Conquer
 *
 * @author open201
 *
 */
public class Ono {
  /**
   * f(n) = s.length = n;
   *
   * @param s
   * @param q
   * @return
   */
  public static int BrutalForceSearch(int[] s, int q) {
    for (int i = 0; i < s.length; i++) {
      if (q == s[i])
        return i;
    }
    return -1;
  }
  /**
   * f(n) = log(n)
   *
   * @param s
   * @param q
   * @return
   */
  public static int DCSearch(int[] s, int q, int startIndex, int endIndex) {
    if (startIndex > endIndex)
      return -1;
    else {
      int mid = (startIndex + endIndex) / 2;
      if (s[mid] == q)
        return mid;
      else {
        if (s[mid] > q)
          return DCSearch(s, q, startIndex,mid-1);
        else
          return DCSearch(s, q, mid+ 1,endIndex);
      }
    }
  }
  public static void main(String[] args) {
    int [] s = new int[10000000];
    for(int i = 0;i<10000000;i++){
      s[i] = i;
    }
    int q = 10000000-1;
    long startTime = System.currentTimeMillis();
    System.out.println(BrutalForceSearch(s, q));
    long endTime = System.currentTimeMillis();
    System.out.println(endTime-startTime);
    startTime = System.currentTimeMillis();
    System.out.println(DCSearch(s, q, 0, s.length - 1));
    endTime = System.currentTimeMillis();
    System.out.println(endTime-startTime);
  }
}

更多关于java算法相关内容感兴趣的读者可查看本站专题:《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》

希望本文所述对大家java程序设计有所帮助。


# Java  # 分治算法  # 排序数  # 索引  # 二分搜索  # Java实现二分搜索树的示例代码  # Java基于二分搜索树、链表的实现的集合Set复杂度分析实例详解  # Java分治法与二分搜索算法实例分析  # java 跳转搜索的实现示例  # 操作技巧  # 相关内容  # 感兴趣  # 数据结构  # 给大家  # 更多关于  # 所述  # 程序设计  # 讲述了  # Divid  # Conquer  # force  # method  # brutal  # Ono  # length  # public  # author  # pre  # class 


相关文章: 济南网站制作的价格,历城一职专官方网站?  C++如何将C风格字符串(char*)转换为std::string?(代码示例)  如何通过NAT技术实现内网高效建站?  如何通过宝塔面板实现本地网站访问?  建站之星后台搭建步骤解析:模板选择与产品管理实操指南  *服务器网站为何频现安全漏洞?  如何获取PHP WAP自助建站系统源码?  怎么将XML数据可视化 D3.js加载XML  如何选择长沙网站建站模板?H5响应式与品牌定制哪个更优?  建站之星安装后如何配置SEO及设计样式?  如何通过西部数码建站助手快速创建专业网站?  如何快速打造个性化非模板自助建站?  建站之星导航菜单设置与功能模块配置全攻略  为什么Go需要go mod文件_Go go mod文件作用说明  如何配置WinSCP新建站点的密钥验证步骤?  建站之星收费标准详解:套餐费用及年费价格表一览  青岛网站建设如何选择本地服务器?  西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  网站视频怎么制作,哪个网站可以免费收看好莱坞经典大片?  购物网站制作公司有哪些,哪个购物网站比较好?  开封网站制作公司,网络用语开封是什么意思?  建站主机核心功能解析:服务器选择与网站搭建流程指南  如何在香港免费服务器上快速搭建网站?  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  昆明网站制作哪家好,昆明公租房申请网上登录入口?  如何在Ubuntu系统下快速搭建WordPress个人网站?  实现点击下箭头变上箭头来回切换的两种方法【推荐】  专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?  家庭建站与云服务器建站,如何选择更优?  广州顶尖建站服务:企业官网建设与SEO优化一体化方案  深圳企业网站制作设计,在深圳如何网上全流程注册公司?  c# Task.ConfigureAwait(true) 在什么场景下是必须的  建站之星如何实现五合一智能建站与营销推广?  兔展官网 在线制作,怎样制作微信请帖?  SQL查询语句优化的实用方法总结  网站制作公司排行榜,抖音怎样做个人官方网站  c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】  如何通过服务器快速搭建网站?完整步骤解析  建站之星后台管理:高效配置与模板优化提升用户体验  如何用wdcp快速搭建高效网站?  jQuery 常见小例汇总  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  如何通过IIS搭建网站并配置访问权限?  建站之星免费模板:自助建站系统与智能响应式一键生成  历史网站制作软件,华为如何找回被删除的网站?  如何选择服务器才能高效搭建专属网站?  建站之星后台管理如何实现高效配置?  网站制作员失业,怎样查看自己网站的注册者?  如何解决ASP生成WAP建站中文乱码问题? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。