Java实现类似类似百度搜索模糊关键字
package com.test;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import java.util.UUID;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
public class Test {
static boolean flag = true;// 默认使用名称去排序
static String msg = "{\"code\":17,\"resut\":1,\"msg\":\"根据商圈管理员ID获取所有的商家\",\"data\":{\"list\":[{\"name\":\"美宜佳\",\"id\":3},{\"name\":\"老王面馆\",\"id\":4},{\"name\":\"大润发\",\"id\":5},{\"name\":\"阿卡丽弄\",\"id\":6},{\"name\":\"555\",\"id\":9},{\"name\":\"好了咯JJ\",\"id\":11},{\"name\":\"路路通\",\"id\":14},{\"name\":\"钟表店\",\"id\":15},{\"name\":\"bloom弄\",\"id\":16},{\"name\":\"上班车啊\",\"id\":18},{\"name\":\"1额考虑欧诺LOL\",\"id\":19}]}}";
public static void main(String[] args) {
// 1、初始化数据
Map<String, Integer> cmap = new HashMap<String, Integer>();
JSONObject fromObject = JSONObject.fromObject(msg);
JSONArray jsonArray = fromObject.getJSONObject("data").getJSONArray("list");
for (Object object : jsonArray) {
JSONObject j = (JSONObject) object;
String name = j.getString("name");
int id = j.getInt("id");
cmap.put(name, id);
}
// 2、加入假数据
for (int i = 0; i < 1000; i++) {
UUID uuid = UUID.randomUUID();
String random = uuid.toString().replaceAll("-", "").substring(0, 8);
int intFlag = (int) (Math.random() * 10000);
cmap.put(random, intFlag);
}
System.out.println("-------------------数据插入完毕----------------------------");
long currentTimeMillis = System.currentTimeMillis();
// 3、模糊匹配数据
Map<String, Integer> likeByMap = getLikeByMap(cmap, "a");
System.out.println("模糊查询到的结果:\n" + likeByMap);
long currentTimeMillis2 = System.currentTimeMillis();
System.out.println("使用时间:" + (currentTimeMillis2 - currentTimeMillis));
}
/**
* Map集合模糊匹配
*
* @param map map集合
* @param keyLike 模糊key
* @return {a1=1,a1899=1899}
*/
public static Map<String, Integer> getLikeByMap(Map<String, Integer> map, String keyLike) {
/** 返回的数据map **/
Map<String, Integer> m = new LinkedHashMap<>();
/** 用于排序数据集合 **/
List<String> l = new LinkedList<>();
// 循环匹配
for (Map.Entry<String, Integer> entity : map.entrySet()) {
String key = entity.getKey();
String integer = map.get(key) + "";
if (key.equals(keyLike)) {// 判断名称完全相等
String a = key + "&" + integer;
l.add(0, a);// 放在第一位
continue;
}
if (integer.equals(keyLike)) {// 判断ID完全相等
String a = key + "&" + integer;
l.add(0, a);// 放在第一位
flag = false;
continue;
}
if (key.indexOf(keyLike) > -1) {// 判断key值
String a = key + "&" + integer;
l.add(a);
}
if (integer.indexOf(keyLike) > -1) {// 判断value
String a = key + "&" + integer;
l.add(a);
}
}
// 将数据长短进行排序
// 将第一个数据取出,不排序
// 判断第一个是否为完全匹配到的
if (null != l) {
if (l.size() > 0) {
String one = l.get(0);
if (one.contains("&")) {
String[] split = one.split("&");
String name = split[0];
String id = split[1];
if (name.equals(keyLike) || id.equals(keyLike)) {
l.remove(0);
} else {
one = null;
}
}
List<String> test = new LinkedList<>();
if (flag) {// 名称
for (String string : l) {
String[] split = string.split("&");
String name = split[0];
test.add(name);
}
} else {// ID
for (String string : l) {
String[] split = string.split("&");
String id = split[1];
test.add(id);
}
}
List<String> sort = Sort(test);
List<String> list = new LinkedList<>();
if (flag) {
for (int i = 0; i < sort.size(); i++) {
String string = sort.get(i).toString();
Integer integer = map.get(string);
list.add(i, string + "&" + integer);
}
} else {
for (int i = 0; i < sort.size(); i++) {
String string = sort.get(i);
for (Map.Entry<String, Integer> entity : map.entrySet()) {
String key = entity.getKey();
String integer = map.get(key) + "";
if (integer.equals(string)) {
list.add(i, key + "&" + integer);
}
}
}
}
if (null != one) {
list.add(0, one);
}
for (String res : list) {
String[] split = res.split("&");
String name = split[0];
String id = split[1];
m.put(name, Integer.valueOf(id));
}
}
}
return m;
}
/**
* 排序
*
* @param stringList
* @return
*/
public static List<String> Sort(List<String> stringList) {
String[] arr = stringList.stream().toArray(String[]::new);
for (int i = 0; i < arr.length - 1; i++) {// 外层循环控制排序趟数
for (int j = 0; j < arr.length - 1 - i; j++) {// 内层循环控制每一趟排序多少次
if (arr[j].length() > arr[j + 1].length()) {
String temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
List<String> succlist = new ArrayList<String>();
for (int i = 0; i < arr.length; i++) {
String string = arr[i];
succlist.add(i, string);
}
return succlist;
}
}
Java实现类似类似百度搜索模糊关键字的更多相关文章
- Ruby用百度搜索爬虫
Ruby用百度搜索爬虫 博主ruby学得断断续续,打算写一个有点用的小程序娱乐一下,打算用ruby通过百度通道爬取网络信息. 第三方库准备 mechanize:比较方便地处理网络请求,类似于Pytho ...
- C#+Selenium抓取百度搜索结果前100网址
需求 爬取百度搜索某个关键字对应的前一百个网址. 实现方式 VS2017 + Chrome .NET Framework + C# + Selenium(浏览器自动化测试框架) 环境准备 创建控制台应 ...
- JavaScript实现模糊推荐的input框(类似百度搜索框)
如何用JS实现一个类似百度搜索框的输入框呢,再填充完失去焦点时,自动填充配置项,最终效果如下图: 实现很简单,但是易用性会上升一大截,需要用到的有jquery-ui的autocomplete,jque ...
- Ajax以及类似百度搜索框的demo
public class Ajax01 extends HttpServlet{ @Override protected void service(HttpServletRequest request ...
- js/jQuery实现类似百度搜索功能
一.页面代码:<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www. ...
- vue 使用watch监听实现类似百度搜索功能
watch监听方法,watch可以监听多个变量,具体使用方法看代码: HTML: <!doctype html> <html lang="en"> < ...
- 百度搜索 “Java面试题” 前200页(面试必看)
前言 本文中的题目来源于网上的一篇文章<百度搜索 "Java面试题" 前200页>,但该文章里面只有题目,没有答案.因此,我整理了一些答案发布于本文.本文整理答案的原则 ...
- 安卓贴图源码--->单点触控.多点触控.类似in/百度魔图
效果如图: 类似in,百度魔图,的贴图功能 核心的地方:单/多点 旋转缩放后记录各个顶点小图标位置 引用这里 http://blog.csdn.net/xiaanming/article/detai ...
- 百度搜索URL参数 搜索关键字
http://www.baidu.com/s?wd=关键字 wd(Keyword):查询的关键词: http://www.baidu.com/s?wd=关键字&cl=3 cl(Class):搜 ...
随机推荐
- 关于Collections的操作方法
Collections是一个包装类,其中包含有各种有关集合操作的静态多态方,比如可以作用在List和Set上,此类不能实例化. 排序 Integer[] array = new Integer[]{3 ...
- ROS初次实践(小海龟)
启动ROS Master 启动小海龟仿真器 启动海龟控制节点(方向键控制海龟运动) rqt_graph可视化工具 /rosout节点必须存在,订阅所有节点的日志信息. 当前系统当中存在的节点. 了解当 ...
- Myeclipse设置自动联想功能
///声明,博客园暂无转载功能,这篇博客是转载自贞心真义. 最近初学Java,正在使用MyEclipse来编写新的项目,刚开始打开MyEclipse感觉这个工具既陌生又熟悉,熟悉之处在于编辑器的几大共 ...
- QuantLib 金融计算——收益率曲线之构建曲线(1)
目录 QuantLib 金融计算--收益率曲线之构建曲线(1) YieldTermStructure DiscountCurve DiscountCurve 对象的构造 ZeroCurve ZeroC ...
- git配置教程
一.配置ssh 1.检查本机是否有ssh key设置 如果没有则提示: No such file or directory 如果有则进入~/.ssh路径下(ls查看当前路径文件,rm删除所有文件) 2 ...
- SPI 用户空间的读写操作
spi_device 虽然用户空间不需要直接用到spi_device结构体,但是这个结构体和用户空间的程序有密切的关系,理解它的成员有助于理解SPI设备节点的IOCTL命令,所以首先来介绍它.在内核中 ...
- TX2 之tensorflow环境部署
刷机jetpack3.3 首先TX2必须是3.3版本的jetpack,因为截止目前nvidia发布的tensorflow只支持3.3版本的jetpack,刷机的具体步骤可以参考NVIDIA Jetso ...
- uml地址栏参数特殊字符处理
转义方法: function URLencode(sStr) { return escape(sStr).replace(/\+/g, '%2B').replace(/\"/g,'%22') ...
- mysql中权限的小知识
参考:https://www.cnblogs.com/apollo1616/articles/10294490.html mysql中user表中host列的值的意义 % 匹配所有主机 localho ...
- springcloud(十)-Zuul微服务网关
为什么要使用微服务网关 前面的文章我们介绍了,Eureka用于服务的注册于发现,Feign支持服务的调用以及均衡负载,Hystrix处理服务的熔断防止故障扩散,Spring Cloud Config服 ...