自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(14)
  • 收藏
  • 关注

原创 iOS敏感词过滤,DFA算法的OC实现

最近给项目加个屏蔽敏感词的功能,在网上搜了一遍基本都是使用DFA算法由敏感词构造树,然后按照遍历输入文本,每次从树的根节点往下匹配,匹配成功则替换成*之类的即可,搜了一圈没有发现OC版的算法,故按着算法用OC写了一遍,分享一波。  类定义如下:#import "WordFilter.h"#define EXIST @"isExists"@interface WordFilter

2016-10-17 23:07:27 5400 2

原创 Android之内存缓存——LruCache的使用及原理

Android的缓存方法有内存缓存和磁盘缓存,像一些实时的图片展示一般都是用内存缓存的,例如微博、朋友圈的图片;而一些相对固定的图片数据比如有些客户端的图片资源需要从网上下载然后存到磁盘中,以后每次启动只需从缓存中获取即可。今天就来探究一下内存缓存的实现及其原理。Android的内存缓存使用LruCache类实现,如果容器已满,就使用LRU置换算法替换掉某个数据。什么是LRU置换算法呢?L

2016-06-07 23:33:57 1349

原创 Java的反射机制与动态代理学习笔记

最近在补Java基础,看到了类型信息这块知识,记起某些Android api和一些库里都有用到反射或动态代理的知识,特此探究一番。一、反射首先百度到的定义:JAVA反射是在运行状态中,对于任意一个类,都能获取这个类的所有属性和方法,对于任意一个对象,都能够调用它的任意一个方法和属性;这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制。看定义能够知道反射就是

2016-05-28 01:52:49 555

原创 Java+Android实现DES与四种模式、AES、MD5算法三合一

上密码学实验课要求程序实现DES、AES和MD5三个算法,就用较熟悉的Java并顺便在Android上写个界面。github地址:https://github.com/w3cboss/DES实现DES算法时走了点弯路,输入输出都用十六进制数字,中间转化为二进制字符串后又转化为boolean型的ArrayList进行各种中间操作,多此一举了,后面也懒得改了。。AES同样用十六进制数字作输

2016-05-23 23:52:44 481

原创 数据结构(c)——排序算法

排序是将一个记录的任意序列,重新排列成一个按关键字有序的序列(按非递减或非递增)。排序算法按排序过程中依据的不同原则可以大致分为五类:插入排序、交换排序、选择排序、归并排序、基数排序。下面程序均使无序序列排序成非递减序列。数据结构使用顺序表,并初始化8个元素 [49,38,65,97,76,13,27,49],typedef struct Record{ int key;

2016-05-14 13:19:33 976

原创 数据结构(c)——赫夫曼树与赫夫曼编码

二叉树的一个重要应用——赫夫曼树(最优二叉树),即所有叶子结点的平均带权路径最短。赫夫曼算法叙述如下:(1)根据给定的n个权值{w1,w2,...wn}构成n棵二叉树的集合F={T1,,T2,...,Tn},其中每棵二叉树Ti中只有一个带权为wi的根结点,其左右子树均空;(2)在F中选取两棵根结点的权值最小的树作为左右子树构造一棵新的二叉树,且置新的二叉树的根结点的权值为其左、右子树上

2016-05-03 20:03:02 1528 1

原创 数据结构(c)——二叉树

二叉树的顺序结构只适用于完全二叉树(与满二叉树的结点编码一一对应的二叉树),否则最坏的情况一个深度为k且只有k个结点的单支树却需要2的k次方-1个单位的存储空间。即二叉树一般用链式结构,链式结构又有二叉链表和三叉链表。不同之处在于三叉链表多了一个指针域保存指向其双亲的指针,当所有空链域都用来保存其他信息如前继或后继,就成了线索链表。二叉链表需要一个值域,分别指向左、右子数的指针,定义如下:

2016-04-30 21:14:47 594 1

原创 对ViewPager+Fragment的懒加载的小小探究

在网上搜索了一些ViewPager+Fragment懒加载的实现方法,基本都是利用setUserVisibleHint()方法中判断当前fragment是否可见,可见则执行加载操作。懒加载frgment父类提供一个加载数据的抽象方法:public abstract class LazyFragment extends Fragment { protected boolean isVis

2016-04-29 10:22:52 2346

原创 数据结构(c)——队列

队列是先进先出(FIFO)的线性表,元素从队尾进从队头出,有的时候也是比较常用的,同样分为顺序存储结构和链式存储结构,其中顺序存储结构可以实现循环队列。1、链式队列首先同样先定义结构体,同样队列应包含有队头指针和队尾指针,分别指向头结点和队尾结点,而指向的结点需有数据域和指向下个结点的指针域:#include #include #include typedef struct Q

2016-04-23 23:11:51 458

原创 数据结构(c)——栈

数据结构中栈还是比较常用的,在某些特定情况下非常便利,例如进制转化等。栈又称为后进先出的线性表(LIFO),同样分为顺序栈和链式栈,实现起来顺序栈和顺序表差不多,链式栈和链式队列差不多而且更加简单。顺序栈的实现和顺序表类似,首先定义宏,存储空间初始分配量和每次再分配的增量,以及结构体表示数据结构。#include #include #include //定义

2016-04-20 12:41:35 680

原创 数据结构(c)——线性表:顺序表和链式表

因为已经大三下学期,准备暑假找实习,以前学得渣,这段时间恶补下基础!!数据结构和算法搞起线性表包括顺序存储和链式存储两种形式。1、顺序表首先定义宏,为线性表分配初始内存空间和再分配用定义结构体,内部定义指针作为线性表的基址,动态分配后就可以用下标访问,跟数组一样,数组a[10],a是指向第一个元素的指针,#define LIST_INIT_SIZE 100 //首次分配的

2016-04-16 15:26:34 992

原创 AndroidStudio下初涉NDK开发

虽然具体还没有需要用到NDK开发,但先了解一下也是好的,所以搭建了一下NDK环境并配置尝试第一个helloworld,在网上找了很多文章,都略微有点不清楚,在此整理总结一下在AndroidStudio开发JNI过程。一、下载NDK,配置环境变量 看了个网上视频教程是在eclipse下,需要用NDK的命令行,发现在AndroidStudio下不用,方便极了。。NDK翻墙到官网下,或者百度,这

2016-04-05 22:13:39 373

原创 零碎笔记——Git的简易使用

知识还是自己稍加整理、总结的好。项目开发的时候可能会用到版本控制器,学着使用了一会Git,总结一下简单常用的知识。      版本控制器顾名思义就是能控制提交项目的历史版本,每提交一次就是一个版本,随时可以回退到各个历史版本。Git是分布式版本控制器,在自己本地就能用得很嗨,当然也可以推送到远程仓库如Github公开自己的项目或者说和队友共同开发等等。  一、使用准备       安装

2016-03-25 00:08:44 498

原创 Android Studio获取SHA1、MD5以及申请第三方平台key

这两天在写些定位天气之类的demo,因此到高德开发者平台上申请SDK,大家都知道使用这些第三方平台都要为自己的应用申请唯一的key,申请key就需要查看数字签名的SHA1或MD5码,这两天找了相关的内容,加以整理作为学习过程的总结,也希望能给到同样有疑惑的初学者们哈。       首先,我们的IDE打包出来的APK文件分为两种,debug(调试)版和release(发布)版,在studio或e

2016-03-11 18:05:38 1145

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除