- 木瓜移动每日资讯0520:字节跳动创始人张一鸣宣布卸任CEO
木瓜出海快讯
❄出海相关:(1)5月20日,字节跳动创始人张一鸣发布内部全员信,宣布卸任CEO一职。字节跳动联合创始人梁汝波将接任成为新CEO。(2)HolyCorn,俄罗斯的一个初创快消品牌,通过在短视频平台Likee上的整合营销,将ROI做到1400%,一举拿下了今年俄罗斯地区艾菲奖“品效合一”银奖和“高性价比品宣”铜奖两座奖杯。❄游戏行业:(1)SensorTower商店情报数据显示,2021年Q1美国手
- C++使用sort函数对学生的成绩进行排序
你今天刷题了吗?
C/C++的学习蓝桥杯c++stl
文章目录一、题意二、代码1.代码的实现2.读入数据三、总结一、题意制作一个简单的排序程序,首先在第一行输入一个数据n代表一共有n个学生,然后再依次输入每个学生的成绩和姓名。并且对该成绩表加以输出,按成绩从大到小进行排序,如果两个学生的成绩相等,则按照名字的字典顺序进行排序。二、代码1.代码的实现代码如下(示例)://使用sort函数对学生的信息进行排序如果成绩相同,则按照名字的字典顺序进行排序#i
- 10_JavaScript数组排序和高阶方法
东东__net
开发语言javascript
目录一、数据类型之间存储的区别(重点)二、数据类型之间的比较三、数组的排序3.1sort排序3.2冒泡排序3.3选择排序四、数组的高阶方法forEach遍历map(映射)一、数据类型之间存储的区别(重点)数据类型分成基本数据类型numberstringbooleannullundefined复杂数据类型ObjectArray....可以通过new关键字创建出来的对象都是复杂数据类型数据类型存储区别
- 推荐一款强大的Django管理界面排序工具:django-admin-sortable2
郎轶诺
推荐一款强大的Django管理界面排序工具:django-admin-sortable2django-admin-sortable2Genericdrag-and-droporderingforobjectsintheDjangoadmininterface项目地址:https://gitcode.com/gh_mirrors/dj/django-admin-sortable2项目介绍django
- LeetCode(977):有序数组的平方
慕洋男孩
LeetCode经典题leetcodec语言
有序数组的平方题目链接题目:给你一个按非递减顺序排序的整数数组nums,返回每个数字的平方组成的新数组,要求也按非递减顺序排序。//暴力#includevoidsort(int*nums,intn){for(inti=0;inums[j]){inttemp=nums[i];nums[i]=nums[j];nums[j]=temp;}}}intmain(){intnums[]={-4,-1,0,3,
- 代码随想录day2 Java版
洒水水儿
代码随想录打卡java算法leetcode
1.有序数组的平方因为数组本身有序,因此最大值只出现在两端,想到左右指针classSolution{publicint[]sortedSquares(int[]nums){int[]res=newint[nums.length];inti=0,j=nums.length-1,k=nums.length-1;while(i=nums[j]*nums[j]){res[k--]=nums[i]*nums
- 探索Python中的快速排序算法
_L1u_J14n
算法排序算法数据结构python
探索Python中的快速排序算法快速排序(QuickSort)是一种非常高效的排序算法,广泛应用于各种编程语言中。与冒泡排序、插入排序和选择排序等简单排序算法相比,快速排序具有更优越的时间复杂度,尤其在处理大型数据集时表现突出。本文将介绍快速排序的原理、实现方法以及其时间复杂度。快速排序的工作原理快速排序是一种基于分治法的排序算法。它通过递归地将数组分成两部分来实现排序。具体步骤如下:选择一个基准
- Linux:一些命令记录
dingcho
运维linuxmongodb运维
netstat-antp|grep-i27017|awk'{print$5}'|cut-d:-f1|sort|uniq-c|sort-n查看磁盘大小du-sh/usr/local/*查看剩余内存:free-mlinux下获取占用CPU资源最多的10个进程,可以使用如下命令组合:psaux|head-1;psaux|grep-vPID|sort-rn-k+3|headlinux下获取占用内存资源最多
- 第6关:部分快速排序-用分治法实现
ye_min_
头歌作业算法
任务描述本关任务:输入正整数k,在数组(无序)中找出第k个最小的数。(1>n;sort(b,b+10);cout<<"the"<<n<<"leastnumberis:";cout<<b[n-1];}
- 数据结构:选择排序的实现
z_鑫
数据结构数据结构排序算法算法c语言
概要选择排序(SelectionSort)是一种原地比较排序算法,核心思想是每轮从未排序区选择极值(最小/最大),与未排序区起点交换。整体架构流程初始状态:将整个数组视为未排序区域,已排序区域为空。遍历未排序区域:从当前未排序区域中找到最小值(或最大值)的索引。交换元素:将找到的最小值与未排序区域的第一个元素交换位置,将该元素归入已排序区域。重复操作:缩小未排序区域的范围,重复上述步骤,直到所有元
- 保研机试复习(一)——算法初步
冠long馨
数据结构与算法算法数据结构PTA
文章目录1.排序1.1选择排序1.2插入排序1.3sort排序1.4排名的实现2.散列2.1整数散列2.2字符串hash2.3map参考资料[1]算法笔记——胡凡、曾磊1.排序1.1选择排序(1)算法思路对于序列a[n]中的元素1~n:令i从1到n枚举,进行n次操作。每趟从待排序部分a[1:n]中选择最小元素,并与待排序部分第一个元素a[i]交换。a[i]与有序部分a[1:i-1]形成新的有序部分
- DeepSORT 目标追踪算法详解
reset2021
目标追踪目标跟踪计算机视觉人工智能
DeepSORT(DeepSimpleOnlineandRealtimeTracking)是多目标追踪(MOT)领域的经典算法,通过结合目标检测、运动预测和外观特征匹配,实现了高效、稳定的实时追踪。其核心思想是通过检测驱动追踪(Tracking-by-Detection),在目标检测的基础上,利用卡尔曼滤波预测目标运动轨迹,并通过Re-ID特征解决遮挡和ID切换问题。一、DeepSORT核心组件1
- vector容器
乘秋川
C++基础语法c++
vector容器如何排序在C++中,可以使用std::sort函数对std::vector进行排序。std::sort是定义在头文件中的函数,可以对容器中的元素进行升序或降序排序。1.升序排序默认情况下,std::sort会对vector中的元素进行升序排序。#include#include#includeintmain(){std::vectorvec={5,2,9,1,5,6};//升序排序s
- 代码随想录算法训练营第二十三天 | 回溯算法part02| 39. 组合总和、40.组合总和II、131.分割回文串
boguboji
刷题算法数据结构
39.组合总和这道题和前面组合问题的区别是,取的元素可以重复,也就是遍历的时候,同一个元素可以一直取。所以for循环里,逐个添加元素,判断和大于目标时break(否则会一直加)还是新建二维数组放结果,一维数组放path。输入参数为放结果数组、path、提供的数组、目标值、目前总和sum、startIndex提前把提供的数组排序,用Arrays.sort()这样sum超过target就break递归
- Redis中的数据类型与适用场景
cooldream2009
数据库redis数据库缓存
目录前言1.字符串(String)1.1特点1.2适用场景2.哈希(Hash)2.1特点2.2适用场景3.列表(List)3.1特点3.2适用场景4.集合(Set)4.1特点4.2适用场景5.有序集合(SortedSet)5.1特点5.2适用场景6.Redis数据类型的选型建议结语前言Redis作为一款高性能的内存数据库,以其卓越的速度和丰富的数据类型广泛应用于各类高并发场景。相较于传统的关系型数
- LeetCode 21Merge Two Sorted Lists 合并两个排序链表 Java
我欲混吃与等死
LeetCodeleetcode链表java
题目:将两个已排序的链表合并在一起。举例1:输入:list1=[1,2,4],list2=[1,3,4];输出:[1,1,2,3,4,4];举例2:输入:list1=[],list2=[];输出:[]举例3:输入:list1=[],list2=[0];输出:[0]解题思路:遍历两个链表,比较节点值来合并链表,当其中一个链表遍历完成时,将另一个链表剩余部分拼入新链表。/***Definitionfo
- 蓝桥大使【算法赛】----贪心算法
wyshh119
算法学习贪心算法
这里比较的难点在于sort排序的根据是什么,为什么是两人的报酬差,我的理解是当两人报酬差越大,那么总报酬的损失就越大,其实是缺少具体的证明的,但是通过就说明确实是这样。也就不深究证明了。#include#includeusingnamespacestd;longlongans=0;constintN=100005;structnode{//结构体inta;intb;};nodea[N];intma
- K8S遇到过的比较深刻的Pod问题
Gold Steps.
技术博文分享kubernetes容器云原生故障处理
第一案:Pod集体自杀凌晨12点的告警总是格外刺眼。值班群里突然炸出一连串消息:"支付服务全部下线!但Pod日志显示一切正常!"运维组赶到战场时,发现大量Pod像多米诺骨牌般接连消失,监控面板上却全是绿色对勾。错误排查:#查看案发时间线kubectlgetevents--sort-by='.lastTimestamp'|grep-ikilled#查看Pod详细信息kubectldescribepo
- python中列表排序
hedgehog"
pythonpythonlist
Python中列表的排序方法1.sort()方法2.sorted()方法========================================1.sort()函数,无返回值主要参数:(1)key:用来进行比较的元素,指定可迭代对象的一个元素作为参数来进行排序。(2)reverse:排序规则。reverse=True降序排序reverse=False升序排序(默认)示例1:list1=[5
- python 列表排序
rainynights
Python
在我们实际使用中,对于列表的操作是十分常见的。对于列表的数据,在很多特殊的情况下我们需要对列表内的数据进行排列以达到我们特定的显示需求。今天,我们一起看一下python中关于列表排序的一些知识。有些时候我们希望对列表进行排序后,列表可以保存我们排序后的结果,但是很多情况下我们只是希望通过列表的排序,临时的显示排序结果而已。所以对于列表的排序可以分为永久性的排序和临时性的排序。sort()sort(
- ElasticSearch~查询操作~(简单查询、批量查询、匹配查询、模糊查询、精确查询、范围查询、通配符查询、must查询、should查询、过滤查询)
飞Link
Elasticelasticsearchlucene全文检索
一、简单查询一、查询所有结果GET/student_info/_search{"query":{"match_all":{}}}二、根据条件查询GET/student_info/_search{"query":{"match":{"name":"张三"}}}三、排序GET/student_info/_search{"query":{"match":{"name":"张三"}},"sort":[{"
- 算法之魂:深入剖析数据结构中的七大排序算法
GeminiGlory
数据结构数据结构排序算法算法
目录1.冒泡排序(BubbleSort)2.选择排序(SelectionSort)3.插入排序(InsertionSort)4.希尔排序(ShellSort)5.快速排序(QuickSort)6.归并排序(MergeSort)7.堆排序(HeapSort)在计算机科学领域,排序是一项基础但至关重要的操作。无论你是处理数据库查询结果还是优化搜索效率,了解不同的排序算法及其适用场景都至关重要。本文将介
- 贪心算法-455分发饼干
工大一只猿
贪心算法算法
classSolution{public:intfindContentChildren(vector&g,vector&s){sort(g.begin(),g.end());sort(s.begin(),s.end());intcount=0;inti=g.size()-1;intj=s.size()-1;for(i;i>=0;i--){if(j>=0&&s[j]>=g[i]){j--;count
- java常用排序方法集合sort
吗喽对你问好
java开发语言数据结构
1.Arrays.sortArrays.sort是用于对数组进行排序的静态方法,位于java.util.Arrays类中。特点:只能用于数组(包括基本类型数组和对象数组)。对基本类型数组(如int[],double[]等)使用快速排序(Dual-PivotQuicksort)。对对象数组(如Integer[],String[]等)使用归并排序(TimSort)。排序是原地进行的(即直接修改原数组)
- vue中根据html动态渲染内容
今天吃了嘛o
vue.jshtmljavascript
需求:根据数据中的html,因为我是在做填空,所以是需要将html中的_____替换成input,由于具体需求我使用的是元素contenteditable代替的可编辑的inputhtml部分js部分//这个是为了保证输入的时候光标保持在最后constmoveCursorToEnd=(element:HTMLElement)=>{constrange=document.createRange();c
- Redis操作命令详解
HaYiBoy
软件工具安装数据库缓存redis
Redis(RemoteDictionaryServer,远程字典服务)是一个开源的键值存储系统,通常用作数据库、缓存或消息传递系统。它支持多种数据结构,如字符串(strings)、哈希(hashes)、列表(lists)、集合(sets)、有序集合(sortedsets)等。本文将详细介绍Redis的一些常用操作命令,帮助你更好地使用Redis。1.连接命令1.1redis-cliredis-c
- 写leetcode常用的库函数和常量
xsh219
golang小知识点算法数据结构golang
在Go中刷LeetCode,以下是一些常用的标准库函数和数据类型的最大值、最小值:✅常用标准库函数数学与排序math包math.Max(x,y):返回两个float64类型数中的较大值。math.Min(x,y):返回两个float64类型数中的较小值。math.Abs(x):取绝对值。math.Pow(x,y):计算x^y。math.Sqrt(x):计算平方根。sort包sort.Ints(sl
- 12.12【java exp4】react table全局搜索tailwindcss 布局 (Layout) css美化 3. (rowId: number
CQU_JIAKE
CQUCSjavascript前端react.js
reacttable创建一个下拉菜单,允许用户选择要搜索的列。创建一个输入框,用于输入搜索关键词。根据用户的选择,动态地应用过滤器到指定的列全局搜索importReactfrom'react';import{useTable,useFilters,useGlobalFilter,useSortBy,usePagination}from'react-table';//自定义过滤组件functionC
- C 中调用WIN32API函数
就叫二号人物
http://www.pinvoke.net/磐实文章站(首页)首页>VisualBasic软件开发资料>API函数http://www.panshsoft.com/Sort_VB/API_fun/GetWindowRect用法http://blog.csdn.net/coolszy/article/details/5601455函数功能:该函数返回指定窗口的边框矩形的尺寸。该尺寸以相对于屏幕坐标
- 怎样用Java实现快速排序与找到数组中第k小的值?
上官美丽
java算法排序算法
大家好,今天我们来聊聊在Java中如何实现快速排序算法,以及如何利用这个排序算法来找到一个数组中的第k小的值。这两个主题在算法和数据结构的学习中都非常重要,理解这些内容对编写高效程序有很大的帮助!快速排序(QuickSort)是一种非常流行的排序算法,因为它在平均情况下表现得非常迅速。它的基本思路是通过一个“基准”值将数组分为两部分,然后递归对这两部分进行排序。听起来简单吧!接下来,我们深入了解一
- ASM系列四 利用Method 组件动态注入方法逻辑
lijingyao8206
字节码技术jvmAOP动态代理ASM
这篇继续结合例子来深入了解下Method组件动态变更方法字节码的实现。通过前面一篇,知道ClassVisitor 的visitMethod()方法可以返回一个MethodVisitor的实例。那么我们也基本可以知道,同ClassVisitor改变类成员一样,MethodVIsistor如果需要改变方法成员,注入逻辑,也可以
- java编程思想 --内部类
百合不是茶
java内部类匿名内部类
内部类;了解外部类 并能与之通信 内部类写出来的代码更加整洁与优雅
1,内部类的创建 内部类是创建在类中的
package com.wj.InsideClass;
/*
* 内部类的创建
*/
public class CreateInsideClass {
public CreateInsideClass(
- web.xml报错
crabdave
web.xml
web.xml报错
The content of element type "web-app" must match "(icon?,display-
name?,description?,distributable?,context-param*,filter*,filter-mapping*,listener*,servlet*,s
- 泛型类的自定义
麦田的设计者
javaandroid泛型
为什么要定义泛型类,当类中要操作的引用数据类型不确定的时候。
采用泛型类,完成扩展。
例如有一个学生类
Student{
Student(){
System.out.println("I'm a student.....");
}
}
有一个老师类
- CSS清除浮动的4中方法
IT独行者
JavaScriptUIcss
清除浮动这个问题,做前端的应该再熟悉不过了,咱是个新人,所以还是记个笔记,做个积累,努力学习向大神靠近。CSS清除浮动的方法网上一搜,大概有N多种,用过几种,说下个人感受。
1、结尾处加空div标签 clear:both 1 2 3 4
.div
1
{
background
:
#000080
;
border
:
1px
s
- Cygwin使用windows的jdk 配置方法
_wy_
jdkwindowscygwin
1.[vim /etc/profile]
JAVA_HOME="/cgydrive/d/Java/jdk1.6.0_43" (windows下jdk路径为D:\Java\jdk1.6.0_43)
PATH="$JAVA_HOME/bin:${PATH}"
CLAS
- linux下安装maven
无量
mavenlinux安装
Linux下安装maven(转) 1.首先到Maven官网
下载安装文件,目前最新版本为3.0.3,下载文件为
apache-maven-3.0.3-bin.tar.gz,下载可以使用wget命令;
2.进入下载文件夹,找到下载的文件,运行如下命令解压
tar -xvf apache-maven-2.2.1-bin.tar.gz
解压后的文件夹
- tomcat的https 配置,syslog-ng配置
aichenglong
tomcathttp跳转到httpssyslong-ng配置syslog配置
1) tomcat配置https,以及http自动跳转到https的配置
1)TOMCAT_HOME目录下生成密钥(keytool是jdk中的命令)
keytool -genkey -alias tomcat -keyalg RSA -keypass changeit -storepass changeit
- 关于领号活动总结
alafqq
活动
关于某彩票活动的总结
具体需求,每个用户进活动页面,领取一个号码,1000中的一个;
活动要求
1,随机性,一定要有随机性;
2,最少中奖概率,如果注数为3200注,则最多中4注
3,效率问题,(不能每个人来都产生一个随机数,这样效率不高);
4,支持断电(仍然从下一个开始),重启服务;(存数据库有点大材小用,因此不能存放在数据库)
解决方案
1,事先产生随机数1000个,并打
- java数据结构 冒泡排序的遍历与排序
百合不是茶
java
java的冒泡排序是一种简单的排序规则
冒泡排序的原理:
比较两个相邻的数,首先将最大的排在第一个,第二次比较第二个 ,此后一样;
针对所有的元素重复以上的步骤,除了最后一个
例题;将int array[]
- JS检查输入框输入的是否是数字的一种校验方法
bijian1013
js
如下是JS检查输入框输入的是否是数字的一种校验方法:
<form method=post target="_blank">
数字:<input type="text" name=num onkeypress="checkNum(this.form)"><br>
</form>
- Test注解的两个属性:expected和timeout
bijian1013
javaJUnitexpectedtimeout
JUnit4:Test文档中的解释:
The Test annotation supports two optional parameters.
The first, expected, declares that a test method should throw an exception.
If it doesn't throw an exception or if it
- [Gson二]继承关系的POJO的反序列化
bit1129
POJO
父类
package inheritance.test2;
import java.util.Map;
public class Model {
private String field1;
private String field2;
private Map<String, String> infoMap
- 【Spark八十四】Spark零碎知识点记录
bit1129
spark
1. ShuffleMapTask的shuffle数据在什么地方记录到MapOutputTracker中的
ShuffleMapTask的runTask方法负责写数据到shuffle map文件中。当任务执行完成成功,DAGScheduler会收到通知,在DAGScheduler的handleTaskCompletion方法中完成记录到MapOutputTracker中
- WAS各种脚本作用大全
ronin47
WAS 脚本
http://www.ibm.com/developerworks/cn/websphere/library/samples/SampleScripts.html
无意中,在WAS官网上发现的各种脚本作用,感觉很有作用,先与各位分享一下
获取下载
这些示例 jacl 和 Jython 脚本可用于在 WebSphere Application Server 的不同版本中自
- java-12.求 1+2+3+..n不能使用乘除法、 for 、 while 、 if 、 else 、 switch 、 case 等关键字以及条件判断语句
bylijinnan
switch
借鉴网上的思路,用java实现:
public class NoIfWhile {
/**
* @param args
*
* find x=1+2+3+....n
*/
public static void main(String[] args) {
int n=10;
int re=find(n);
System.o
- Netty源码学习-ObjectEncoder和ObjectDecoder
bylijinnan
javanetty
Netty中传递对象的思路很直观:
Netty中数据的传递是基于ChannelBuffer(也就是byte[]);
那把对象序列化为字节流,就可以在Netty中传递对象了
相应的从ChannelBuffer恢复对象,就是反序列化的过程
Netty已经封装好ObjectEncoder和ObjectDecoder
先看ObjectEncoder
ObjectEncoder是往外发送
- spring 定时任务中cronExpression表达式含义
chicony
cronExpression
一个cron表达式有6个必选的元素和一个可选的元素,各个元素之间是以空格分隔的,从左至右,这些元素的含义如下表所示:
代表含义 是否必须 允许的取值范围 &nb
- Nutz配置Jndi
ctrain
JNDI
1、使用JNDI获取指定资源:
var ioc = {
dao : {
type :"org.nutz.dao.impl.NutDao",
args : [ {jndi :"jdbc/dataSource"} ]
}
}
以上方法,仅需要在容器中配置好数据源,注入到NutDao即可.
- 解决 /bin/sh^M: bad interpreter: No such file or directory
daizj
shell
在Linux中执行.sh脚本,异常/bin/sh^M: bad interpreter: No such file or directory。
分析:这是不同系统编码格式引起的:在windows系统中编辑的.sh文件可能有不可见字符,所以在Linux系统下执行会报以上异常信息。
解决:
1)在windows下转换:
利用一些编辑器如UltraEdit或EditPlus等工具
- [转]for 循环为何可恨?
dcj3sjt126com
程序员读书
Java的闭包(Closure)特征最近成为了一个热门话题。 一些精英正在起草一份议案,要在Java将来的版本中加入闭包特征。 然而,提议中的闭包语法以及语言上的这种扩充受到了众多Java程序员的猛烈抨击。
不久前,出版过数十本编程书籍的大作家Elliotte Rusty Harold发表了对Java中闭包的价值的质疑。 尤其是他问道“for 循环为何可恨?”[http://ju
- Android实用小技巧
dcj3sjt126com
android
1、去掉所有Activity界面的标题栏
修改AndroidManifest.xml 在application 标签中添加android:theme="@android:style/Theme.NoTitleBar"
2、去掉所有Activity界面的TitleBar 和StatusBar
修改AndroidManifes
- Oracle 复习笔记之序列
eksliang
Oracle 序列sequenceOracle sequence
转载请出自出处:http://eksliang.iteye.com/blog/2098859
1.序列的作用
序列是用于生成唯一、连续序号的对象
一般用序列来充当数据库表的主键值
2.创建序列语法如下:
create sequence s_emp
start with 1 --开始值
increment by 1 --増长值
maxval
- 有“品”的程序员
gongmeitao
工作
完美程序员的10种品质
完美程序员的每种品质都有一个范围,这个范围取决于具体的问题和背景。没有能解决所有问题的
完美程序员(至少在我们这个星球上),并且对于特定问题,完美程序员应该具有以下品质:
1. 才智非凡- 能够理解问题、能够用清晰可读的代码翻译并表达想法、善于分析并且逻辑思维能力强
(范围:用简单方式解决复杂问题)
- 使用KeleyiSQLHelper类进行分页查询
hvt
sql.netC#asp.nethovertree
本文适用于sql server单主键表或者视图进行分页查询,支持多字段排序。KeleyiSQLHelper类的最新代码请到http://hovertree.codeplex.com/SourceControl/latest下载整个解决方案源代码查看。或者直接在线查看类的代码:http://hovertree.codeplex.com/SourceControl/latest#HoverTree.D
- SVG 教程 (三)圆形,椭圆,直线
天梯梦
svg
SVG <circle> SVG 圆形 - <circle>
<circle> 标签可用来创建一个圆:
下面是SVG代码:
<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
<circle cx="100" c
- 链表栈
luyulong
java数据结构
public class Node {
private Object object;
private Node next;
public Node() {
this.next = null;
this.object = null;
}
public Object getObject() {
return object;
}
public
- 基础数据结构和算法十:2-3 search tree
sunwinner
Algorithm2-3 search tree
Binary search tree works well for a wide variety of applications, but they have poor worst-case performance. Now we introduce a type of binary search tree where costs are guaranteed to be loga
- spring配置定时任务
stunizhengjia
springtimer
最近因工作的需要,用到了spring的定时任务的功能,觉得spring还是很智能化的,只需要配置一下配置文件就可以了,在此记录一下,以便以后用到:
//------------------------定时任务调用的方法------------------------------
/**
* 存储过程定时器
*/
publi
- ITeye 8月技术图书有奖试读获奖名单公布
ITeye管理员
活动
ITeye携手博文视点举办的8月技术图书有奖试读活动已圆满结束,非常感谢广大用户对本次活动的关注与参与。
8月试读活动回顾:
http://webmaster.iteye.com/blog/2102830
本次技术图书试读活动的优秀奖获奖名单及相应作品如下(优秀文章有很多,但名额有限,没获奖并不代表不优秀):
《跨终端Web》
gleams:http