- java笔记——Map循环指南
啊健的影子
java笔记python
一、遍历Map的三种方法Java中的Map是一种以键值对形式存储数据的容器,常用的实现类有HashMap、LinkedHashMap和TreeMap。遍历Map是我们在使用Map时最常遇到的问题之一,下面介绍三种常用的遍历方法。1.通过entrySet遍历Mapmap=newHashMap();map.put(1,"one");map.put(2,"two");map.put(3,"three")
- java-collection类
在下陈平安
javajava开发语言
前言:collection类下面有多个实现子类,每个实现子类都不一样,通过梳理每个实现子类,快速掌握便于日常工作。关系图:Collection└──List└──Set└──Map└──Queue└──ArrayList└──LinkedList└──HashSet└──TreeSet└──HashMap└──LinkedHashMap└──Queue└──ArrayDequeCollection
- 2024 java面试题
TPBoreas
#Java面试开发语言后端
目录JAVA初级请简述你对MVC模式的理解SpringBean的生命周期可以分为以下几步:Spring自动装配bean有哪些方式?说一下类的加载过程?在使用HashMap的时候,用String做key有什么好处?HashMap、LinkedHashMap、TreeMap的区别?this与super之间有什么区别?乐观锁和悲观锁的实现是怎么样的?==与equals的区别Final在java中有什么作
- mybatis 返回结果Map类型时保证字段顺序
qq_36608622
mybatistomcatjava
在MyBatis中,当你使用Map作为查询结果的返回类型时,默认情况下字段顺序是不保证的,因为Java的HashMap不维护插入顺序。然而,从Java1.7开始,LinkedHashMap类可以按照插入顺序维护元素。因此,如果你希望保持字段的顺序,你可以让MyBatis返回LinkedHashMap而不是默认的HashMap。方法1:使用resultType="java.util.LinkedHa
- Map
VirtualBool
java学习java
Map是Java中用于存储键值对的集合接口。以下是对Map的详细介绍:特点键值对存储:每个元素包含一个键和一个值。键唯一:键不能重复,但值可以重复。无序/有序:根据具体实现,键值对的顺序可能无序(如HashMap)或有序(如TreeMap、LinkedHashMap)。主要实现类HashMap基于哈希表,无序存储。允许一个null键和多个null值。LinkedHashMap继承自HashMap,
- android pdf框架-8,图片缓存
archko
pdfpdfandroid
解码会产生很多图片,滑过后不要显示,如果直接回收,会浪费不少资源.在没有缓存的情况下,会看到gc还是比较频繁的.有了缓存后,明显gc少了.目录常用的缓存自定义缓存显示相关的内存缓存解码缓存池内存缓存实现:解码缓存池实现:常用的缓存lrucache,这是最常用的,也是androidsdk里面有的.就是按访问时间顺序,内部使用linkedhashmap,会记录访问时间.androidx.core.ut
- LinkedHashMap源码简读
tinyvampirepudg
LinkedHashMap源码简读1、LinkedHashMap继承自HashMap,HashMap具有的特性它都具有。2、实际上,LinkedHashMap是通过双向链表和散列表这两种数据组合实现的。LinkedHashMap中的“Linked”实际上指的是双向链表,并非指“用链表法解决散列冲突”。3、LinkedHashMap不仅支持按照插入顺序遍历数据,还支持按照访问顺序来遍历数据。通过设置
- 集合进阶(双列集合、HashMap、LinkedHashMap、TreeMap、Collections)
小琪爱学习
Java黑马java开发语言
目录一、双列集合1、双列集合的特点2、双列集合的常见API3、Map的遍历方式3.1第一种遍历方式:键找值(keySet)3.2第二种遍历方式:键值对(entrySet)Entry:键值对对象3.3第三种遍历方式:Lambda表达式(forEach)二、HsahMap集合1、HashMap的特点2、HashMap的底层原理3、小结4、HashMap练习4.1存储学生对象并遍历4.2Map集合案例-
- TreeMap就这么简单【源码剖析】
Java3y
前言声明,本文用得是jdk1.8前面章节回顾:Collection总览List集合就这么简单【源码剖析】Map集合、散列表、红黑树介绍HashMap就是这么简单【源码剖析】LinkedHashMap就这么简单【源码剖析】本篇主要讲解TreeMap~看这篇文章之前最好是有点数据结构的基础:Java实现单向链表栈和队列就是这么简单二叉树就这么简单当然了,如果讲得有错的地方还请大家多多包涵并不吝在评论去
- 【视频】互联网Java工程师面试突击训练(三季)
后端
视频下载地址https://pan.quark.cn/s/2c7e785e3500目录一、Java集合包HashMap的底层数据结构是什么?JDK1.8中对hash算法和寻址算法是如何优化的?03.HashMap是如何解决hash碰撞问题的?04.说说HashMap是如何进行扩容的?05.ArrayList,LinkedList,TreeMap,LinkedHashMap,HashSet等底层的数
- 【集合系列】LinkedHashMap 集合
酷小洋
#Java基础语法java开发语言b树
LinkedHashMap集合1.概述2.方法3.遍历方式4.代码示例5.注意事项其他集合类祖父类Map父类HashMap集合类的遍历方式具体信息请查看API帮助文档1.概述LinkedHashMap是Java中的一种特殊类型的HashMap,它继承自HashMap类,并实现了Map接口。它是一个有序的集合,它保留了元素插入的顺序,并且允许使用它们的插入顺序进行迭代。与普通的HashMap不同,L
- 【集合系列】HashMap 集合
酷小洋
#Java基础语法java开发语言
HashMap集合1.概述2.方法3.遍历方式4.代码示例15.代码示例26.注意事项7.源码分析其他集合类父类Map实现类LinkedHashMap集合类的遍历方式具体信息请查看API帮助文档1.概述HashMap是Java中的一种集合类,它实现了Map接口。HashMap使用键值对存储数据,每个键值对被称为一个Entry(条目)。HashMap使用哈希表来存储数据,因此能够在O(1)时间复杂度
- 【链表】-Lc146-实现LRU(巧妙借助LinkedHashMap)
宝总.
数据结构与算法链表java数据结构
写在前面 最近想复习一下数据结构与算法相关的内容,找一些题来做一做。如有更好思路,欢迎指正。目录写在前面一、场景描述二、具体步骤1.环境说明2.代码写在后面一、场景描述 运用你所掌握的数据结构,设计和实现一个LRU(LeastRecentlyUsed,最近最少使用)缓存机制。它应该支持以下操作,获取数据get和写入数据put。1、获取数据get(key),如果密钥(key)存在于缓存中,则获取
- java Map集合相关介绍和方法使用操作
酷爱码
java技术教程java开发语言
Java的Map集合是存储键值对的一种数据结构。在Map中,每个键都是唯一的,用来标识该键值对。Map接口是java.util包中的一部分,它有多个实现类,包括HashMap,TreeMap,LinkedHashMap等。下面是Map接口的一些常用方法:put(key,value):向Map中插入一个键值对。get(key):根据键获取对应的值。containsKey(key):判断Map中是否存
- lambda表达式LinkedHashMap::new和Collectors.mapping讲解
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ
java
List>>result=list.stream().collect(Collectors.groupingBy(ReviewRecord::getNodeType,LinkedHashMap::new,Collectors.mapping(Function.identity(),Collectors.toList()))).entrySet().stream().collect(Collecto
- 大模型: OpenAi流式会话报错【org.springframework.http.converter.HttpMessageNotWritableException: No converter 】
玉成226
【大模型】ai
文章目录一、背景二、解決方案一、背景使用OkHttpClient-sse流式会话报如下错误信息Resolved[org.springframework.http.converter.HttpMessageNotWritableException:Noconverterfor[classjava.util.LinkedHashMap]withpresetContent-Type'text/event
- Java基础 LinkedHashMap
一名技术极客
java相关随笔javaLinkedHashMap
LinkedHashMapLinkedHashMap定义LinkedHashMap的原理图LinkedHashMap和HashMap的Entry结构图LinkedHashMap在JDK中的定义LinkedHashMap继承关系:LinkedHashMap成员变量LinkedHashMap构造方法(5种)LinkedHashMap的init()方法LinkedHashMap基本数据结构(Entry:
- Java集合-Map接口(key-value)
猿究院-废柴火鸡
java开发语言
Map接口的特点:①KV键值对方式存储②Key键唯一,Value允许重复③无序。Map有四个实现类:1.HashMap类2.LinkedHashMap类3.TreeMap类4.Hashtable类1.HashMap类:存储结构:哈希表=数组Node[]+链表(红黑树)扩容方法:resize()扩容机制:原数组的2倍特点:①Key唯一,不允许重复②Value允许重复③无序HashMap:KV键值对集
- SpringBoot中 LinkedHashMap cannot be cast to xxx解决方法
TODOcode
SpringBoot中LinkedHashMapcannotbecasttoxxx解决方法.jpghttps://blog.csdn.net/cxycxytony/article/details/108931425
- redis java.util.LinkedHashMap cannot be cast to XXX
夏夜里的晚风。
java
这种问题是Redis中取出来的值,强转成我们需要的类型时报错解决:比如我们需要转User类Objectobj=valueOperations.get(key);Useru=JSON.parseObject(JSON.toJSONString(obj),User.class);
- java.util.LinkedHashMap cannot be cast to xxx
hjjksjin
java开发语言
java.util.LinkedHashMapcannotbecasttocom.entity.Person使用mybatis,resultMap映射的是实体类Person,查询出来的结果是一个ArrayList,然后结果存放在一个ListObject的data属性中,存放结果的类publicclassListObject{privateObjectdata;publicObjectgetData
- java.lang.ClassCastException: java.util.LinkedHashMap cannot be cast to XXX
张三疯学独孤九剑
记录bugfeignException
java.lang.ClassCastException:java.util.LinkedHashMapcannotbecasttoXXX今天在用feign进行远程调用的时候报错java.lang.ClassCastException:java.util.LinkedHashMapcannotbecasttoXXX类型转换异常这里是consumer调用方logger.info("添加评论方法被调用
- java中be cast to_java.util.LinkedHashMap cannot be cast to xxx
周博磊
java中becastto
java.util.LinkedHashMapcannotbecasttocom.entity.Person使用mybatis,resultMap映射的是实体类Person,查询出来的结果是一个ArrayList,然后结果存放在一个ListObject的data属性中,存放结果的类publicclassListObject{privateObjectdata;publicObjectgetData
- 23. 集合类
酷小洋
#Java基础语法java开发语言
集合1.概述2.分类2.1单列集合(`Collection`)2.2双列集合(`Map`)单列集合Collection、List、Set、ArrayList、LinkedList’、Vector、HashSet、TreeSet、LinkedHashSet双列集合Map、HashTable、HashMap、TreeMap、Properties、LinkedHashMap具体信息请查看API帮助文档1
- 集合框架 Map接口的特点及具体实现类HashMap、 LinkedHashMap、TreeMap、Hashtable
甜甜不甜1001
java开发语言
Map接口特点:key-value键值对集合,键key唯一,值value允许重复常见实现类HashMap:无序LinkedHashMap:有序TreeMap:按照key自动排序Hashtable:无序线程安全,性能低不允许使用null做key不允许使用null做valuepackagecom.ztt.Demo02;importjava.util.Arrays;importjava.util.Has
- Java 数据结构集合
Artisan_w
Java基础与八股java数据结构开发语言
文章目录Java数据结构1.基本数据结构1.1数组(Array)1.2链表(LinkedList)1.3栈(Stack)1.4队列(Queue)双向队列优先级队列2.树形数据结构2.1二叉树(BinaryTree)2.2堆(Heap)3.散列数据结构3.1哈希表(HashMap)3.2LinkedHashMap3.3TreeMapConcurrentHashMap详解ConcurrentHashM
- 解决:Jackson反序列化Java内部类失败(序列化后的识别码为LinkedHashMap,而非内部类本身)
SerikaOnoe
JavaJacksonjackson内部类反序列化JavaJsonTypeInfoJsonSubTypes
问题描述先看实体类:importcom.fasterxml.jackson.annotation.*;importlombok.Data;importorg.jeecg.common.system.base.entity.JeecgEntity;importorg.jeecg.modules.iot.entity.jackson.WorkerConverter;importorg.jeecg.mo
- 3分钟搞掂Set集合
Java3y
前言声明,本文用的是jdk1.8前面章节回顾:Collection总览List集合就这么简单【源码剖析】Map集合、散列表、红黑树介绍HashMap就是这么简单【源码剖析】LinkedHashMap就这么简单【源码剖析】TreeMap就这么简单【源码剖析】ConcurrentHashMap基于JDK1.8源码剖析现在这篇主要讲Set集合的三个子类:HashSet集合A:底层数据结构是哈希表(是一个
- Groovy语言基础
明明_白_白
1.分号不是必须的2.单引号和双引号都可以定义一个字符串常量3.单引号没有运算能力,双引号有运算能力。双引号中调用变量的规则是一个美元符号紧跟着一对花括号,花括号里放表达式,比如{1+1}等,只有一个变量的时候可以省略花括号,如{it.key},Value:${it.value}"}输出:map的类型:java.util.LinkedHashMap1024440Key:width,Value:10
- 中间件存储设计 - 数组与链表
善守的大龙猫
中间件中间件链表java
文章目录数组ArrayListLinkedListHashMap小结中间件主要包括如下三方面的基础:数据结构、JUC和Netty,接下来,我们先讲数据结构。数据结构主要解决的是数据的存储方式问题,是程序设计的基座。按照重要性和复杂程度,我选取了数组和链表、键值对(HashMap)、红黑树、LinkedHashMap和PriorityQueue几种数据结构重点解析。其中,数组与链表是最底层的两种结构
- 关于旗正规则引擎规则中的上传和下载问题
何必如此
文件下载压缩jsp文件上传
文件的上传下载都是数据流的输入输出,大致流程都是一样的。
一、文件打包下载
1.文件写入压缩包
string mainPath="D:\upload\"; 下载路径
string tmpfileName=jar.zip; &n
- 【Spark九十九】Spark Streaming的batch interval时间内的数据流转源码分析
bit1129
Stream
以如下代码为例(SocketInputDStream):
Spark Streaming从Socket读取数据的代码是在SocketReceiver的receive方法中,撇开异常情况不谈(Receiver有重连机制,restart方法,默认情况下在Receiver挂了之后,间隔两秒钟重新建立Socket连接),读取到的数据通过调用store(textRead)方法进行存储。数据
- spark master web ui 端口8080被占用解决方法
daizj
8080端口占用sparkmaster web ui
spark master web ui 默认端口为8080,当系统有其它程序也在使用该接口时,启动master时也不会报错,spark自己会改用其它端口,自动端口号加1,但为了可以控制到指定的端口,我们可以自行设置,修改方法:
1、cd SPARK_HOME/sbin
2、vi start-master.sh
3、定位到下面部分
- oracle_执行计划_谓词信息和数据获取
周凡杨
oracle执行计划
oracle_执行计划_谓词信息和数据获取(上)
一:简要说明
在查看执行计划的信息中,经常会看到两个谓词filter和access,它们的区别是什么,理解了这两个词对我们解读Oracle的执行计划信息会有所帮助。
简单说,执行计划如果显示是access,就表示这个谓词条件的值将会影响数据的访问路径(表还是索引),而filter表示谓词条件的值并不会影响数据访问路径,只起到
- spring中datasource配置
g21121
dataSource
datasource配置有很多种,我介绍的一种是采用c3p0的,它的百科地址是:
http://baike.baidu.com/view/920062.htm
<!-- spring加载资源文件 -->
<bean name="propertiesConfig"
class="org.springframework.b
- web报表工具FineReport使用中遇到的常见报错及解决办法(三)
老A不折腾
finereportFAQ报表软件
这里写点抛砖引玉,希望大家能把自己整理的问题及解决方法晾出来,Mark一下,利人利己。
出现问题先搜一下文档上有没有,再看看度娘有没有,再看看论坛有没有。有报错要看日志。下面简单罗列下常见的问题,大多文档上都有提到的。
1、repeated column width is largerthan paper width:
这个看这段话应该是很好理解的。比如做的模板页面宽度只能放
- mysql 用户管理
墙头上一根草
linuxmysqluser
1.新建用户 //登录MYSQL@>mysql -u root -p@>密码//创建用户mysql> insert into mysql.user(Host,User,Password) values(‘localhost’,'jeecn’,password(‘jeecn’));//刷新系统权限表mysql>flush privileges;这样就创建了一个名为:
- 关于使用Spring导致c3p0数据库死锁问题
aijuans
springSpring 入门Spring 实例Spring3Spring 教程
这个问题我实在是为整个 springsource 的员工蒙羞
如果大家使用 spring 控制事务,使用 Open Session In View 模式,
com.mchange.v2.resourcepool.TimeoutException: A client timed out while waiting to acquire a resource from com.mchange.
- 百度词库联想
annan211
百度
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>RunJS</title&g
- int数据与byte之间的相互转换实现代码
百合不是茶
位移int转bytebyte转int基本数据类型的实现
在BMP文件和文件压缩时需要用到的int与byte转换,现将理解的贴出来;
主要是要理解;位移等概念 http://baihe747.iteye.com/blog/2078029
int转byte;
byte转int;
/**
* 字节转成int,int转成字节
* @author Administrator
*
- 简单模拟实现数据库连接池
bijian1013
javathreadjava多线程简单模拟实现数据库连接池
简单模拟实现数据库连接池
实例1:
package com.bijian.thread;
public class DB {
//private static final int MAX_COUNT = 10;
private static final DB instance = new DB();
private int count = 0;
private i
- 一种基于Weblogic容器的鉴权设计
bijian1013
javaweblogic
服务器对请求的鉴权可以在请求头中加Authorization之类的key,将用户名、密码保存到此key对应的value中,当然对于用户名、密码这种高机密的信息,应该对其进行加砂加密等,最简单的方法如下:
String vuser_id = "weblogic";
String vuse
- 【RPC框架Hessian二】Hessian 对象序列化和反序列化
bit1129
hessian
任何一个对象从一个JVM传输到另一个JVM,都要经过序列化为二进制数据(或者字符串等其他格式,比如JSON),然后在反序列化为Java对象,这最后都是通过二进制的数据在不同的JVM之间传输(一般是通过Socket和二进制的数据传输),本文定义一个比较符合工作中。
1. 定义三个POJO
Person类
package com.tom.hes
- 【Hadoop十四】Hadoop提供的脚本的功能
bit1129
hadoop
1. hadoop-daemon.sh
1.1 启动HDFS
./hadoop-daemon.sh start namenode
./hadoop-daemon.sh start datanode
通过这种逐步启动的方式,比start-all.sh方式少了一个SecondaryNameNode进程,这不影响Hadoop的使用,其实在 Hadoop2.0中,SecondaryNa
- 中国互联网走在“灰度”上
ronin47
管理 灰度
中国互联网走在“灰度”上(转)
文/孕峰
第一次听说灰度这个词,是任正非说新型管理者所需要的素质。第二次听说是来自马化腾。似乎其他人包括马云也用不同的语言说过类似的意思。
灰度这个词所包含的意义和视野是广远的。要理解这个词,可能同样要用“灰度”的心态。灰度的反面,是规规矩矩,清清楚楚,泾渭分明,严谨条理,是决不妥协,不转弯,认死理。黑白分明不是灰度,像彩虹那样
- java-51-输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。
bylijinnan
java
public class PrintMatrixClockwisely {
/**
* Q51.输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。
例如:如果输入如下矩阵:
1 2 3 4
5 6 7 8
9
- mongoDB 用户管理
开窍的石头
mongoDB用户管理
1:添加用户
第一次设置用户需要进入admin数据库下设置超级用户(use admin)
db.addUsr({user:'useName',pwd:'111111',roles:[readWrite,dbAdmin]});
第一个参数用户的名字
第二个参数
- [游戏与生活]玩暗黑破坏神3的一些问题
comsci
生活
暗黑破坏神3是有史以来最让人激动的游戏。。。。但是有几个问题需要我们注意
玩这个游戏的时间,每天不要超过一个小时,且每次玩游戏最好在白天
结束游戏之后,最好在太阳下面来晒一下身上的暗黑气息,让自己恢复人的生气
&nb
- java 二维数组如何存入数据库
cuiyadll
java
using System;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Xml;
using System.Xml.Serialization;
using System.IO;
namespace WindowsFormsApplication1
{
- 本地事务和全局事务Local Transaction and Global Transaction(JTA)
darrenzhu
javaspringlocalglobaltransaction
Configuring Spring and JTA without full Java EE
http://spring.io/blog/2011/08/15/configuring-spring-and-jta-without-full-java-ee/
Spring doc -Transaction Management
http://docs.spring.io/spri
- Linux命令之alias - 设置命令的别名,让 Linux 命令更简练
dcj3sjt126com
linuxalias
用途说明
设置命令的别名。在linux系统中如果命令太长又不符合用户的习惯,那么我们可以为它指定一个别名。虽然可以为命令建立“链接”解决长文件名的问 题,但对于带命令行参数的命令,链接就无能为力了。而指定别名则可以解决此类所有问题【1】。常用别名来简化ssh登录【见示例三】,使长命令变短,使常 用的长命令行变短,强制执行命令时询问等。
常用参数
格式:alias
格式:ali
- yii2 restful web服务[格式响应]
dcj3sjt126com
PHPyii2
响应格式
当处理一个 RESTful API 请求时, 一个应用程序通常需要如下步骤 来处理响应格式:
确定可能影响响应格式的各种因素, 例如媒介类型, 语言, 版本, 等等。 这个过程也被称为 content negotiation。
资源对象转换为数组, 如在 Resources 部分中所描述的。 通过 [[yii\rest\Serializer]]
- MongoDB索引调优(2)——[十]
eksliang
mongodbMongoDB索引优化
转载请出自出处:http://eksliang.iteye.com/blog/2178555 一、概述
上一篇文档中也说明了,MongoDB的索引几乎与关系型数据库的索引一模一样,优化关系型数据库的技巧通用适合MongoDB,所有这里只讲MongoDB需要注意的地方 二、索引内嵌文档
可以在嵌套文档的键上建立索引,方式与正常
- 当滑动到顶部和底部时,实现Item的分离效果的ListView
gundumw100
android
拉动ListView,Item之间的间距会变大,释放后恢复原样;
package cn.tangdada.tangbang.widget;
import android.annotation.TargetApi;
import android.content.Context;
import android.content.res.TypedArray;
import andr
- 程序员用HTML5制作的爱心树表白动画
ini
JavaScriptjqueryWebhtml5css
体验效果:http://keleyi.com/keleyi/phtml/html5/31.htmHTML代码如下:
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml"><head><meta charset="UTF-8" >
<ti
- 预装windows 8 系统GPT模式的ThinkPad T440改装64位 windows 7旗舰版
kakajw
ThinkPad预装改装windows 7windows 8
该教程具有普遍参考性,特别适用于联想的机器,其他品牌机器的处理过程也大同小异。
该教程是个人多次尝试和总结的结果,实用性强,推荐给需要的人!
缘由
小弟最近入手笔记本ThinkPad T440,但是特别不能习惯笔记本出厂预装的Windows 8系统,而且厂商自作聪明地预装了一堆没用的应用软件,消耗不少的系统资源(本本的内存为4G,系统启动完成时,物理内存占用比
- Nginx学习笔记
mcj8089
nginx
一、安装nginx 1、在nginx官方网站下载一个包,下载地址是:
http://nginx.org/download/nginx-1.4.2.tar.gz
2、WinSCP(ftp上传工
- mongodb 聚合查询每天论坛链接点击次数
qiaolevip
每天进步一点点学习永无止境mongodb纵观千象
/* 18 */
{
"_id" : ObjectId("5596414cbe4d73a327e50274"),
"msgType" : "text",
"sendTime" : ISODate("2015-07-03T08:01:16.000Z"
- java术语(PO/POJO/VO/BO/DAO/DTO)
Luob.
DAOPOJODTOpoVO BO
PO(persistant object) 持久对象
在o/r 映射的时候出现的概念,如果没有o/r映射,就没有这个概念存在了.通常对应数据模型(数据库),本身还有部分业务逻辑的处理.可以看成是与数据库中的表相映射的java对象.最简单的PO就是对应数据库中某个表中的一条记录,多个记录可以用PO的集合.PO中应该不包含任何对数据库的操作.
VO(value object) 值对象
通
- 算法复杂度
Wuaner
Algorithm
Time Complexity & Big-O:
http://stackoverflow.com/questions/487258/plain-english-explanation-of-big-o
http://bigocheatsheet.com/
http://www.sitepoint.com/time-complexity-algorithms/