O(1)纬度减少循环次数
O(1)纬度减少循环次数
平事看淡,不服就干。老子有句粗口话不知道当不当讲,我们公司上一次发工资时4月4号,时至今日5-30已经有57天没有发工资了,我还要继续坚持下去吗?难不成现在大家工作都TM的不在乎钱了的吗?
使用O(1)纬度减少循环次数,提高代码质量。
需要实现匹配list1 和 list2 中keyName相等的cipher,并把list1中的cipher写入list2:
package com.xinyan.springcloud.tjt; import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map; import org.apache.commons.lang.StringUtils; import lombok.Data; public class CompareOne {
private static List<KeyInfo> list1 = new ArrayList<>();
private static List<CipherPathInfo> list2 = new ArrayList<>(); /**
* 比较low的methodOne设计
*/
public void methodOne() {
// 匹配list1 和 list2 中keyName相等的cipher,并把list1中的cipher写入list2:
// 设计方案1:
for (int i = 0; i < list1.size(); i++) {
KeyInfo keyInfo = list1.get(i);
String keyName = keyInfo.getKeyName();
String cipher = keyInfo.getCipher();
for (int j = 0; j < list2.size(); j++) {
CipherPathInfo cipherPathInfo = list2.get(j);
String keyName2 = cipherPathInfo.getKeyName();
if (StringUtils.equals(keyName, keyName2)) {
cipherPathInfo.setCipher(cipher);
}
}
}
} /**
* 较好的methodTwo设计
*/
public void methodTwo() {
// 匹配list1 和 list2 中keyName相等的cipher,并把list1中的cipher写入list2:
// 设计方案2:
Map<String, String> keyNameMap = new HashMap<>();
// 使用keyNameMap缓存keyName的cipher
for (int i = 0; i < list1.size(); i++) {
KeyInfo keyInfo = list1.get(i);
String keyName = keyInfo.getKeyName();
String cipher = keyInfo.getCipher();
keyNameMap.put(keyName, cipher);
}
// 根据keyName的名称查keyNameMap取出cipher
for (int j = 0; j < list2.size(); j++) {
CipherPathInfo cipherPathInfo = list2.get(j);
String keyName = cipherPathInfo.getKeyName();
String cipher = keyNameMap.get(keyName);
if (StringUtils.isNotEmpty(cipher)) {
cipherPathInfo.setCipher(cipher);
}
}
} /**
* 实体KeyInfo
*
* @author apple
*/
@Data
class KeyInfo {
private String keyName;
private String cipher;
} /**
* 实体CipherPathInfo
*
* @author apple
*/
@Data
class CipherPathInfo {
private String keyName;
private String cipher;
private String path;
} /**
* 构造KeyInfo、CipherPathInfo实体信息
*/
public void makeEntityInfo() {
KeyInfo keyInfo = new KeyInfo();
// 构造30个keyInfo实体
for (int i = 0; i < 30; i++) {
keyInfo.setKeyName("name_" + i);
keyInfo.setCipher("cipher_" + i);
list1.add(keyInfo);
}
CipherPathInfo cipherPathInfo = new CipherPathInfo();
// 构造100个ciperhPathInfo实体,其中cipher为null
for (int j = 0; j < 100; j++) {
cipherPathInfo.setKeyName("name_" + j);
cipherPathInfo.setPath("path_" + j);
list2.add(cipherPathInfo);
}
} public static void main(String[] args) {
CompareOne c = new CompareOne();
c.makeEntityInfo();
// 匹配list1 和 list2 中keyName相等的cipher,并把list1中的cipher写入list2:
// 设计方案1:
c.methodOne();
// 方案1设计明显不合理,很low;其中list1有30个元素,而list2有100个
// 这样就会累计循环30*100次
// 可以将讲list1中获取到的keyName插入哈希中,只需要O(1)的纬度
// 方案设计2:
c.methodTwo(); } }
O(1)纬度减少循环次数的更多相关文章
- 如何更规范化编写Java 代码
如何更规范化编写Java 代码 Many of the happiest people are those who own the least. But are we really so happy ...
- 如何更规范化的编写JAVA 代码
如何更规范的编写JAVA代码 一.MyBatis 不要为了多个查询条件而写 1 = 1 当遇到多个查询条件,使用where 1=1 可以很方便的解决我们的问题,但是这样很可能会造成非常大的性能损失, ...
- MMORPG大型游戏设计与开发(攻击区域 扇形)
距离上次发布已经有了很长一段时间,期间由于各种原因没有更新这方面的技术分享,在这里深表遗憾.在MMO或其他的游戏中,会有针对各种形状的计算,通常在攻击区域里不会很复杂,常见的为矩形.圆形.扇形.今天分 ...
- 延迟求值-如何让Lo-Dash再提速x100?
「注释」作者在本文里没有说明这么一个事实: 目前的版本Lo-Dash v2.4.1并没有引入延迟求值的特性,Lo-Dash 3.0.0-pre中部分方法进行了引入,比如filter(),map(),r ...
- ORACLE应用调优:请避免SQL做大量循环逻辑处理
前阵子遇到一个案例:一个同事说以前一个运行很正常的包,突然间比以前慢了很多,执行时间非常长,晚上的作业调用这个包跑了几个小时也没有跑出数据.于是我在跟踪.优化过程中定位到包中一个存储过程的一段SQL, ...
- MySQL Nested-Loop Join算法学习
不知不觉的玩了两年多的MySQL,发现很多人都说MySQL对比Oracle来说,优化器做的比较差,其实某种程度上来说确实是这样,但是毕竟MySQL才到5.7版本,Oracle都已经发展到12c了,今天 ...
- 百钱买百鸡问题 php版本
/* * 百钱买百鸡问题 * * 我国古代数学家张丘建在<算经>一书中曾提出过著名的“百钱买百鸡”问题,该问题叙述如下:鸡翁一,值钱五:鸡母一,值钱三:鸡雏三,值钱一:百钱买百鸡,则翁.母 ...
- for语句嵌套循坏性能的剖析
日常工作中,处理数据难免会遇到遍历,for循环可能是我们用的比较多的了.本节就来探讨下for语句嵌套循环的性能,猜想下面两个语句的性能. 语句1 ; i < ; i++){ ; j < ; ...
- java经典题目
/***********Ryear.java begin********************/ import java.util.Scanner;public class Ryear { /** ...
随机推荐
- 程序员过关斩将--cookie和session的关系其实很简单
月高风下,下班路上.... 菜菜哥,告诉你一个秘密,但是不允许告诉任何人 这么秘密,你有男票了?~ 不是,昨天我偷偷去面试了,结果挂了 这不是好事吗,上天让公司留住你..... 好吧,不过还是要请教你 ...
- SPP NET (Spatial Pyramid Pooling in Deep Convolutional Networks for Visual Recognition)
1. https://www.cnblogs.com/gongxijun/p/7172134.html (SPP 原理) 2.https://www.cnblogs.com/chaofn/p/9305 ...
- 微信小程序 es6-promise.js封装请求 处理异步进程
下载es6-promise.js置于根目录下的libs文件夹下: 在根目录utils文件夹下新建httpsPromisify.js,即定义封装请求的方法 var Promise = require(' ...
- [Python] Scrapy爬虫框架入门
说明: 本文主要学习Scrapy框架入门,介绍如何使用Scrapy框架爬取页面信息. 项目案例:爬取腾讯招聘页面 https://hr.tencent.com/position.php?&st ...
- Nacos整合Spring Cloud Gateway组件
一.什么是Spring Cloud Gateway Spring Cloud Gateway是Spring Cloud官方推出的网关框架,网关作为流量入口有着非常大的作用,常见的功能有路由转发.权限校 ...
- 2019icpc南京网络赛_F_Greedy Sequence
题意 题意不明,队友告诉我对于每个\(i\),所在下标\(p[i]\),在\([p[i]-k,p[i]+k]\)中找到小于\(i\)的最大数\(x\),然后\(ans[i]=ans[x]+1\)即可. ...
- 创建ASP.NET Webservice
一.WebService:WebService是以独立于平台的方式,通过标准的Web协议,可以由程序访问的应用程序逻辑单元. (1)应用程序逻辑单元:web服务包括一些应用程序逻辑单元或者代码.这些代 ...
- 第10章 文档对象模型DOM 10.3 Element类型
Element 类型用于表现 XML或 HTML元素,提供了对元素标签名.子节点及特性的访问. 要访问元素的标签名,可以使用 nodeName 属性,也可以使用 tagName 属性:这两个属性会返回 ...
- gym/102059/problem/I. Game on Plane SG函数做博弈
传送门: 题意: 给定一个正n边形的点.双方轮流连点成线,要求所画的线不能与之前的线相交.当某个人连成一个回路,这个人就输了.问先手必胜还是后手必胜. 思路: SG函数,因为一条线相当于把图劈成了两半 ...
- 背包形动态规划 fjutoj1380 Piggy-Bank
Piggy-Bank TimeLimit: 2000/1000 MS (Java/Others) MemoryLimit: 65536/32768 K (Java/Others) 64-bit in ...