- xgboost原理
茶尽
阅读XGBoost与BoostedTree基学习器:CART每个叶子节点上面有一个分数不够厉害,所以找一个更强的模型treeensemble对每个样本的预测结果是每棵树预测分数的和目标函数采用boosting(additivetraining)方法,每一次都加入一个新的函数。依赖每个数据点上的误差函数的一阶导数和二阶导(区别于GBDT)。树的复杂度复杂度包含了一棵树里面的叶子个数和输出分数的L2模
- 力扣 hot100 Day49
qq_51397044
Hot100leetcode算法数据结构
105.从前序与中序遍历序列构造二叉树给定两个整数数组preorder和inorder,其中preorder是二叉树的先序遍历,inorder是同一棵树的中序遍历,请构造二叉树并返回其根节点。//抄的classSolution{private:unordered_mapindex;TreeNode*myBuildTree(constvector&preorder,constvector&inord
- 分类树/装袋法/随机森林算法的R语言实现
廖致君
R
原文首发于简书于[2018.06.12]本文是我自己动手用R语言写的实现分类树的代码,以及在此基础上写的袋装法(bagging)和随机森林(randomforest)的算法实现。全文的结构是:分类树基本知识predginisplitrulesplitrule_bestsplitrule_randomsplittingbuildTreepredict装袋法与随机森林基本知识baggingpredic
- vue3 el-select+el-tree实现下拉树形选择
控糖__he
vue.jsjavascript前端
主要功能:多选,移除标签,清空标签,模糊搜索,禁用,全选,清空全选清空import'element-plus/dist/index.css'import{getFileTypeTree}from'@/api/Customer/index'exportdefault{name:'App',data(){return{noticeTypeId:[],//最后获取的选择idtreeProps:{valu
- 有向数据模型(数据建模-USS)
Litlesme
数据建模-USS数据建模数据分析数据库数据仓库数据分析sql
在统一星型模式中,在构建PuppiniBridge(或简称桥接表)前,需要先分析物理数据模型(物理表间的关系),FrancescoPuppini推荐通过绘制单向的ERD(实体关系图)来分析,称这种图叫做有向数据模型(ODM,OrientedDataModel),比如:有向数据模型的模型图的结构是一个有向树(DirectedTree)。实际上在多数实际场景下其实原本的结构是有向无环图(Directe
- Unity动画导演:Animator解密
你一身傲骨怎能输
游戏引擎unity游戏引擎
文章摘要Unity动画系统核心技术解析本文深入剖析Unity动画系统的三大核心技术:一、动画混合原理数学实现:位置混合:线性插值(Lerp)旋转混合:四元数球面插值(Slerp)多动画混合:加权平均公式混合类型:过渡混合、BlendTree混合、动画层混合伪代码展示骨骼变换的混合计算二、动画事件机制功能:在指定动画帧触发预设函数应用场景:伤害判定、音效触发实现方式:AnimationClip内嵌事
- 【数据结构】: 树状数组 (Binary Indexed Trees)
ZONE画派
数据结构
树状数组(BinaryIndexedTrees)November15,2012作者:Hawstein出处:http://hawstein.com/posts/binary-indexed-trees.html声明:本文采用以下协议进行授权:自由转载-非商用-非衍生-保持署名|CreativeCommonsBY-NC-ND3.0,转载请注明作者及出处。前言本文翻译自TopCoder上的一篇文章:Bi
- 树状数组(Binary Indexed Trees)树状数组详解(转载)
u010793761
计算机以及程序语言学习
分类:数据结构树状数组树状数组(BinaryIndexedTrees)November15,2012作者:Hawstein出处:http://hawstein.com/posts/binary-indexed-trees.html声明:本文采用以下协议进行授权:自由转载-非商用-非衍生-保持署名|CreativeCommonsBY-NC-ND3.0,转载请注明作者及出处。topcoder上原英文链
- 树状数组
菜圾
树状数组杂记ACM树状数组
树状数组(BinaryIndexedTrees)November15,2012作者:Hawstein出处:http://hawstein.com/posts/binary-indexed-trees.html声明:本文采用以下协议进行授权:自由转载-非商用-非衍生-保持署名|CreativeCommonsBY-NC-ND3.0,转载请注明作者及出处。前言本文翻译自TopCoder上的一篇文章:Bi
- 【notes】【NERDtree】使用记录
过得精彩
#UbuntunotesvimNERDtree
vimNERDtree安装、配置、使用0.env1.下载、安装(1).下载(2).安装2.配置(1).配置键盘映射(2).进入vim自动打开3.个人常用操作(1).左右窗口切换光标(2).在当前窗口打开xxx且切换光标到该文件窗口(3).在当前窗口打开xxx但不切换光标到该文件窗口(4).显示系统cmdline,执行shellcmd0.envubuntu18-04vim8.01.下载、安装(1).
- 《算法导论(第4版)》阅读笔记:p91-p94
算法
《算法导论(第4版)》学习第20天,p91-p94总结,总计4页。一、技术总结1.recursiontreeIngraphtheory,arecursivetree(i.e.,unorderedtree)isalabeled,rootedtree.Asize-nrecursivetree'sverticesarelabeledbydistinctpositiveintegers1,2,…,n,wh
- Boring counting HDU - 4358(树上出现k次的数字个数)
starlet_kiss
树状数组
InthisproblemweconsiderarootedtreewithNvertices.Theverticesarenumberedfrom1toN,andvertex1representstheroot.Thereareintegerweightsoneachvectice.Yourtaskistoansweralistofqueries,foreachquery,pleasetellu
- C++八股——平衡树总结
四谷夕雨
c++
文章目录1.定义2.各种平衡树2.1AVL树2.2红黑树(Red-BlackTree)2.3B树(B-Tree)2.4B+树(B+Tree)2.5伸展树(SplayTree)2.6Treap2.7替罪羊树(ScapegoatTree)2.82-3树/2-3-4树2.9AA树(AA-Tree)2.10加权平衡树(Weight-BalancedTree)总结对比1.定义平衡树(BalancedTree
- HDU5927 Auxiliary Set(dfs)
KeyboardPianist
HDUdfshdudfs
AuxiliarySetTimeLimit:9000/4500MS(Java/Others)MemoryLimit:65536/65536K(Java/Others)TotalSubmission(s):937AcceptedSubmission(s):289ProblemDescriptionGivenarootedtreewithnvertices,someoftheverticesareim
- Auxiliary Set HDU - 5927(思维题)
coldfresh
思考
Givenarootedtreewithnvertices,someoftheverticesareimportant.Anauxiliarysetisasetcontainingverticessatisfyingatleastoneofthetwoconditions:∙Itisanimportantvertex∙Itistheleastcommonancestoroftwodifferent
- 力扣-105.从前序与中序遍历序列构造二叉树
এ᭄画画的北北
力扣hot100leetcode算法数据结构
题目描述给定两个整数数组preorder和inorder,其中preorder是二叉树的先序遍历,inorder是同一棵树的中序遍历,请构造二叉树并返回其根节点。classSolution{public:TreeNode*buildTree(vector&preorder,vector&inorder){if(preorder.size()==0)returnNULL;TreeNode*root=
- 堆与二叉树——C语言
黄皮の电气鼠
c语言android开发语言
一、顺序表底层#pragmaonce#include#include#includetypedefintdata;typedefstructHeap{data*arr;intsize;intcapacity;}Heap;voidHeapInit(Heap*php);voidHeapDestroy(Heap*php);//把已有堆进行排序voidtreesort(Heap*php);voidHeap
- 组织架构设计、角色与权限设计的一些思考
Java进阶八股文
状态模式
组织架构1.需求点查询某个组织下面的所有用户(包括所有下级组织)查询某个组织下面的所有下级组织查询用户所在的组织获取整个组织结构,方便生成树形数据结构2.组织表相关的必要字段如下:id,主键IDpid,父级组织idtree,当前节点的所有父级组织,假设当前组织的父级id为2,2的父级id为1,则tree的值为:1,23.用户表相关的必要字段如下:department,所在的组织id。4.相关SQL
- CloudCompare 中的 KDTree详解
点云SLAM
点云数据处理技术算法人工智能数据结构数据结构
CloudCompare中的KDTree详解1.什么是KDTree?KDTree是K维空间划分树(K-DimensionalTree),它是一种用于高效查找最近邻点的数据结构。CloudCompare中的KDTree主要用于:最近邻搜索(NearestNeighborSearch)点云匹配和ICP(IterativeClosestPoint)配准点云去噪半径范围搜索点云加速索引相比DgmOctre
- 迭代器组装树结构
bright future cheer
java
以menu为例classMenu{privateLongid;privateStringname;privateLongparentId;privateListchildren;}publicstaticListbuildTreeIteratively(Listmenus,LongrootParentId){Map>menuMap=newHashMap子节点列表的映射for(Menumenu:me
- LeetCode //C - 685. Redundant Connection II
Navigator_Z
LeetCodeleetcodec语言算法
685.RedundantConnectionIIInthisproblem,arootedtreeisadirectedgraphsuchthat,thereisexactlyonenode(theroot)forwhichallothernodesaredescendantsofthisnode,pluseverynodehasexactlyoneparent,exceptfortheroot
- PCL笔记四:k-d tree和八叉树;近邻搜索;半径搜索;体素内搜索;空间变化检测;
逍遥郎wj
PCL八叉树双缓冲八叉树PCL点云变化检测
点云数据主要是表征目标表面的海量点集合,并不具备传统实体网格数据的几何拓扑信息。点云数据处理中最为核心的问题就是建立离散点间的拓扑关系,实现基于邻域关系的快速查找。建立空间索引在点云数据处理中已被广泛应用,常见空间索引一般是自顶向下逐级划分空间的各种空间索引结构:BSP树、k-dtree、KDB树、R树、R+树、CELL树、四叉树、八叉树等。k-dtree对于区间和近邻搜索十分有用。PCL中k-d
- PTA L2-011 玩转二叉树(Python3)
取名字不好取那直接不取了
python
classTreeNode:def__init__(self,val=0,left=None,right=None):self.val=valself.left=leftself.right=rightdefbuildTree(qx,zx):ifnotqxornotzx:returnNoneroot_val=qx[0]root=TreeNode(root_val)zx_index=zx.index
- prism项目搭建 wpf_PRISM WPF-导航每次都会创建新视图
weixin_39588084
prism项目搭建wpf
I'musingPRISM4NavigationAPIwithUnityinWPF.Ihaveatree-viewthatinitiatesaRequestNavigatepassingintheselectedtreenode'sID(GUID)._regionManager.RequestNavigate(RegionNames.DetailRegion,ViewNames.SiteView+
- prism项目搭建 wpf,PRISM WPF-导航每次都会创建新视图
宋世泊
prism项目搭建wpf
I'musingPRISM4NavigationAPIwithUnityinWPF.Ihaveatree-viewthatinitiatesaRequestNavigatepassingintheselectedtreenode'sID(GUID)._regionManager.RequestNavigate(RegionNames.DetailRegion,ViewNames.SiteView+
- 二叉树的ACM板子(自用)
明天不下雨(牛客同名)
windows
package二叉树的中序遍历;importjava.util.*;//定义二叉树节点classTreeNode{intval;//节点值TreeNodeleft;//左子节点TreeNoderight;//右子节点//构造函数TreeNode(intx){val=x;}}publicclassDMain{//构建二叉树(层序遍历方式)publicstaticTreeNodebuildTree(I
- ASP.NET 无限级树的加载
weixin_30457551
OPW_XT_MKOP_W_XT_MK=newOPW_XT_MK(AppPublic.GetConnectionString());protectedvoidPage_Load(objectsender,EventArgse){if(!IsPostBack){//生成树buildTree();}}/**///////添加树形菜单的结构///privatevoidbuildTree(){OP_W_X
- squarified算法
淬渊阁
算法算法c++qt数据结构前端
其他参考资料:https://www.docin.com/p-1509919023.htmlSquarifiedTreemaps论文算法复现_squarified算法-CSDN博客手绘草图,发觉之前网上很多的图都会误导大家去理解算法前处理1首先对输入数据进行排序2对数据数据总和和窗口面积进行等比换手。算法基本思路:原始数据:{6,6,4,3,2,2,1}step1:首先确认最短边,将第一个元素6放
- 7个最好用的Vue Tree Select树形组件
萌尛喵
vue.js前端javascript
Vue树形选择器(Vuetreeselect)组件在搭建Vue的app中特别常用,Vuetreeselect除了简单的树形结构外,还有非常多样的功能来配合不同场景的使用。比如搜索过滤,前端添加删除树枝,前端编辑修改子树名,拖拽排序,对用户操作事件记录等。VueJSTree-全功能,树状单选多选,可拖拽,过滤搜索VueDraggableNestedTree-纯树形选择,轻盈趁手VueTreeList
- vue 移动端树结构功能_【H5】Vue 递归组件构建一个树形菜单
难忘念想
vue移动端树结构功能
Vue.js中的递归组件是一个可以调用自己的组件例如:递归组件一般用于博客上显示评论,树形菜单或者嵌套菜单。一、初始化我们直接使用vue提供的脚手架vue-cli来初始化我们的工程:#搭建项目vueinitwebpack-simpletree-menu#进入项目cdtree-menu#依赖安装npminstall#运行项目npmrundev现在我们的环境已经准备好了,在初始化的项目中,有一些不需要
- 如何用ruby来写hadoop的mapreduce并生成jar包
wudixiaotie
mapreduce
ruby来写hadoop的mapreduce,我用的方法是rubydoop。怎么配置环境呢:
1.安装rvm:
不说了 网上有
2.安装ruby:
由于我以前是做ruby的,所以习惯性的先安装了ruby,起码调试起来比jruby快多了。
3.安装jruby:
rvm install jruby然后等待安
- java编程思想 -- 访问控制权限
百合不是茶
java访问控制权限单例模式
访问权限是java中一个比较中要的知识点,它规定者什么方法可以访问,什么不可以访问
一:包访问权限;
自定义包:
package com.wj.control;
//包
public class Demo {
//定义一个无参的方法
public void DemoPackage(){
System.out.println("调用
- [生物与医学]请审慎食用小龙虾
comsci
生物
现在的餐馆里面出售的小龙虾,有一些是在野外捕捉的,这些小龙虾身体里面可能带有某些病毒和细菌,人食用以后可能会导致一些疾病,严重的甚至会死亡.....
所以,参加聚餐的时候,最好不要点小龙虾...就吃养殖的猪肉,牛肉,羊肉和鱼,等动物蛋白质
- org.apache.jasper.JasperException: Unable to compile class for JSP:
商人shang
maven2.2jdk1.8
环境: jdk1.8 maven tomcat7-maven-plugin 2.0
原因: tomcat7-maven-plugin 2.0 不知吃 jdk 1.8,换成 tomcat7-maven-plugin 2.2就行,即
<plugin>
- 你的垃圾你处理掉了吗?GC
oloz
GC
前序:本人菜鸟,此文研究学习来自网络,各位牛牛多指教
1.垃圾收集算法的核心思想
Java语言建立了垃圾收集机制,用以跟踪正在使用的对象和发现并回收不再使用(引用)的对象。该机制可以有效防范动态内存分配中可能发生的两个危险:因内存垃圾过多而引发的内存耗尽,以及不恰当的内存释放所造成的内存非法引用。
垃圾收集算法的核心思想是:对虚拟机可用内存空间,即堆空间中的对象进行识别
- shiro 和 SESSSION
杨白白
shiro
shiro 在web项目里默认使用的是web容器提供的session,也就是说shiro使用的session是web容器产生的,并不是自己产生的,在用于非web环境时可用其他来源代替。在web工程启动的时候它就和容器绑定在了一起,这是通过web.xml里面的shiroFilter实现的。通过session.getSession()方法会在浏览器cokkice产生JESSIONID,当关闭浏览器,此
- 移动互联网终端 淘宝客如何实现盈利
小桔子
移動客戶端淘客淘寶App
2012年淘宝联盟平台为站长和淘宝客带来的分成收入突破30亿元,同比增长100%。而来自移动端的分成达1亿元,其中美丽说、蘑菇街、果库、口袋购物等App运营商分成近5000万元。 可以看出,虽然目前阶段PC端对于淘客而言仍旧是盈利的大头,但移动端已经呈现出爆发之势。而且这个势头将随着智能终端(手机,平板)的加速普及而更加迅猛
- wordpress小工具制作
aichenglong
wordpress小工具
wordpress 使用侧边栏的小工具,很方便调整页面结构
小工具的制作过程
1 在自己的主题文件中新建一个文件夹(如widget),在文件夹中创建一个php(AWP_posts-category.php)
小工具是一个类,想侧边栏一样,还得使用代码注册,他才可以再后台使用,基本的代码一层不变
<?php
class AWP_Post_Category extends WP_Wi
- JS微信分享
AILIKES
js
// 所有功能必须包含在 WeixinApi.ready 中进行
WeixinApi.ready(function(Api) {
// 微信分享的数据
var wxData = {
&nb
- 封装探讨
百合不是茶
JAVA面向对象 封装
//封装 属性 方法 将某些东西包装在一起,通过创建对象或使用静态的方法来调用,称为封装;封装其实就是有选择性地公开或隐藏某些信息,它解决了数据的安全性问题,增加代码的可读性和可维护性
在 Aname类中申明三个属性,将其封装在一个类中:通过对象来调用
例如 1:
//属性 将其设为私有
姓名 name 可以公开
- jquery radio/checkbox change事件不能触发的问题
bijian1013
JavaScriptjquery
我想让radio来控制当前我选择的是机动车还是特种车,如下所示:
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js" type="text/javascript"><
- AngularJS中安全性措施
bijian1013
JavaScriptAngularJS安全性XSRFJSON漏洞
在使用web应用中,安全性是应该首要考虑的一个问题。AngularJS提供了一些辅助机制,用来防护来自两个常见攻击方向的网络攻击。
一.JSON漏洞
当使用一个GET请求获取JSON数组信息的时候(尤其是当这一信息非常敏感,
- [Maven学习笔记九]Maven发布web项目
bit1129
maven
基于Maven的web项目的标准项目结构
user-project
user-core
user-service
user-web
src
- 【Hive七】Hive用户自定义聚合函数(UDAF)
bit1129
hive
用户自定义聚合函数,用户提供的多个入参通过聚合计算(求和、求最大值、求最小值)得到一个聚合计算结果的函数。
问题:UDF也可以提供输入多个参数然后输出一个结果的运算,比如加法运算add(3,5),add这个UDF需要实现UDF的evaluate方法,那么UDF和UDAF的实质分别究竟是什么?
Double evaluate(Double a, Double b)
- 通过 nginx-lua 给 Nginx 增加 OAuth 支持
ronin47
前言:我们使用Nginx的Lua中间件建立了OAuth2认证和授权层。如果你也有此打算,阅读下面的文档,实现自动化并获得收益。SeatGeek 在过去几年中取得了发展,我们已经积累了不少针对各种任务的不同管理接口。我们通常为新的展示需求创建新模块,比如我们自己的博客、图表等。我们还定期开发内部工具来处理诸如部署、可视化操作及事件处理等事务。在处理这些事务中,我们使用了几个不同的接口来认证:
&n
- 利用tomcat-redis-session-manager做session同步时自定义类对象属性保存不上的解决方法
bsr1983
session
在利用tomcat-redis-session-manager做session同步时,遇到了在session保存一个自定义对象时,修改该对象中的某个属性,session未进行序列化,属性没有被存储到redis中。 在 tomcat-redis-session-manager的github上有如下说明: Session Change Tracking
As noted in the &qu
- 《代码大全》表驱动法-Table Driven Approach-1
bylijinnan
java算法
关于Table Driven Approach的一篇非常好的文章:
http://www.codeproject.com/Articles/42732/Table-driven-Approach
package com.ljn.base;
import java.util.Random;
public class TableDriven {
public
- Sybase封锁原理
chicony
Sybase
昨天在操作Sybase IQ12.7时意外操作造成了数据库表锁定,不能删除被锁定表数据也不能往其中写入数据。由于着急往该表抽入数据,因此立马着手解决该表的解锁问题。 无奈此前没有接触过Sybase IQ12.7这套数据库产品,加之当时已属于下班时间无法求助于支持人员支持,因此只有借助搜索引擎强大的
- java异常处理机制
CrazyMizzz
java
java异常关键字有以下几个,分别为 try catch final throw throws
他们的定义分别为
try: Opening exception-handling statement.
catch: Captures the exception.
finally: Runs its code before terminating
- hive 数据插入DML语法汇总
daizj
hiveDML数据插入
Hive的数据插入DML语法汇总1、Loading files into tables语法:1) LOAD DATA [LOCAL] INPATH 'filepath' [OVERWRITE] INTO TABLE tablename [PARTITION (partcol1=val1, partcol2=val2 ...)]解释:1)、上面命令执行环境为hive客户端环境下: hive>l
- 工厂设计模式
dcj3sjt126com
设计模式
使用设计模式是促进最佳实践和良好设计的好办法。设计模式可以提供针对常见的编程问题的灵活的解决方案。 工厂模式
工厂模式(Factory)允许你在代码执行时实例化对象。它之所以被称为工厂模式是因为它负责“生产”对象。工厂方法的参数是你要生成的对象对应的类名称。
Example #1 调用工厂方法(带参数)
<?phpclass Example{
- mysql字符串查找函数
dcj3sjt126com
mysql
FIND_IN_SET(str,strlist)
假如字符串str 在由N 子链组成的字符串列表strlist 中,则返回值的范围在1到 N 之间。一个字符串列表就是一个由一些被‘,’符号分开的自链组成的字符串。如果第一个参数是一个常数字符串,而第二个是type SET列,则 FIND_IN_SET() 函数被优化,使用比特计算。如果str不在strlist 或st
- jvm内存管理
easterfly
jvm
一、JVM堆内存的划分
分为年轻代和年老代。年轻代又分为三部分:一个eden,两个survivor。
工作过程是这样的:e区空间满了后,执行minor gc,存活下来的对象放入s0, 对s0仍会进行minor gc,存活下来的的对象放入s1中,对s1同样执行minor gc,依旧存活的对象就放入年老代中;
年老代满了之后会执行major gc,这个是stop the word模式,执行
- CentOS-6.3安装配置JDK-8
gengzg
centos
JAVA_HOME=/usr/java/jdk1.8.0_45
JRE_HOME=/usr/java/jdk1.8.0_45/jre
PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin
CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib
export JAVA_HOME
- 【转】关于web路径的获取方法
huangyc1210
Web路径
假定你的web application 名称为news,你在浏览器中输入请求路径: http://localhost:8080/news/main/list.jsp 则执行下面向行代码后打印出如下结果: 1、 System.out.println(request.getContextPath()); //可返回站点的根路径。也就是项
- php里获取第一个中文首字母并排序
远去的渡口
数据结构PHP
很久没来更新博客了,还是觉得工作需要多总结的好。今天来更新一个自己认为比较有成就的问题吧。 最近在做储值结算,需求里结算首页需要按门店的首字母A-Z排序。我的数据结构原本是这样的:
Array
(
[0] => Array
(
[sid] => 2885842
[recetcstoredpay] =&g
- java内部类
hm4123660
java内部类匿名内部类成员内部类方法内部类
在Java中,可以将一个类定义在另一个类里面或者一个方法里面,这样的类称为内部类。内部类仍然是一个独立的类,在编译之后内部类会被编译成独立的.class文件,但是前面冠以外部类的类名和$符号。内部类可以间接解决多继承问题,可以使用内部类继承一个类,外部类继承一个类,实现多继承。
&nb
- Caused by: java.lang.IncompatibleClassChangeError: class org.hibernate.cfg.Exten
zhb8015
maven pom.xml关于hibernate的配置和异常信息如下,查了好多资料,问题还是没有解决。只知道是包冲突,就是不知道是哪个包....遇到这个问题的分享下是怎么解决的。。
maven pom:
<dependency>
<groupId>org.hibernate</groupId>
<ar
- Spark 性能相关参数配置详解-任务调度篇
Stark_Summer
sparkcachecpu任务调度yarn
随着Spark的逐渐成熟完善, 越来越多的可配置参数被添加到Spark中来, 本文试图通过阐述这其中部分参数的工作原理和配置思路, 和大家一起探讨一下如何根据实际场合对Spark进行配置优化。
由于篇幅较长,所以在这里分篇组织,如果要看最新完整的网页版内容,可以戳这里:http://spark-config.readthedocs.org/,主要是便
- css3滤镜
wangkeheng
htmlcss
经常看到一些网站的底部有一些灰色的图标,鼠标移入的时候会变亮,开始以为是js操作src或者bg呢,搜索了一下,发现了一个更好的方法:通过css3的滤镜方法。
html代码:
<a href='' class='icon'><img src='utv.jpg' /></a>
css代码:
.icon{-webkit-filter: graysc