- BZOJ4059: [Cerc2012]Non-boring sequences
forezxl
BZOJ数据结构---线段树蒟蒻zxl的Blog专栏
线段树题目传送门这道题正解是启发式分治,不过线段树也能做。和这道题很像,同样记一个nxt[i]nxt[i]nxt[i]表示a[i]a[i]a[i]下一次出现的位置,枚举左端点,撤销[i,nxt[i]−1][i,nxt[i]-1][i,nxt[i]−1],加上[nxt[i],nxt[nxt[i]]−1][nxt[i],nxt[nxt[i]]-1][nxt[i],nxt[nxt[i]]−1],并判断[
- 题解 UVA1608 【不无聊的序列 Non-boring sequences】
Arthuer
思路:算法很显然:一、在区间\([l,r]\)找到一个只出现一次的元素P(如果不存在,那么序列\(boring\))二、递归处理区间\([l,p-1]\)和区间\([p+1,r]\)。其关键在于如何找到一个只出现一次的元素P。首先,我们得知道如何判断一个元素是不是只出现一次。我们可以用\(STL\)中的\(map\)记录与当前元素值相同的上一个元素or下一个元素的位置,然后更新即可。因为\(map
- [UVA] Non-boring sequences
Lei_lz
C++数据结构
题目:https://vjudge.net/problem/UVA-1608#include#include#include#include#include#include#include#include#include#include#include#include#pragmawarning(disable:4996)usingnamespacestd;constintmaxn=200000+
- 【NOIP模拟】序列
baizu1991
【问题描述】一个序列被称为有趣的序列是它的所有的子串拥有一个唯一的整数(这个整数在整个序列中只出现过一次)。给你一个序列的整数,问你它是否是有趣的。【输入格式】第一行T,表示数据组数。接下来每组数据第一行一个n。接下来是n个整数,均小于10^9。【输出格式】输出boring或者non-boring。【输入样例】4512345511111512321511211【输出样例】non-boringbor
- 启发式分治入门 Non-boring sequences UVA - 1608
*Zzz
参考自:https://blog.csdn.net/XY20130630/article/details/50635756题意:一个序列被称为是不无聊的,仅当它的每个连续子序列存在一个独一无二的数字,即每个子序列里至少存在一个数字只出现一次。给定一个整数序列,请你判断它是不是不无聊的。分析:预处理每个元素上一次出现位置和下一个出现位置,我们发现对于一个子序列[L,R]来说,如果存在pre[i]R那
- Non-boring seqences
weixin_30300523
原文链接:http://www.cnblogs.com/rign/p/11297973.html#includeusingnamespacestd;#definefore(i,_a,_b)for(inti=(int)(_a);i=(int)(_b);i--)#definefirfirst#definesecsecond#defineSZ(a)(int)(a).size()#definepbpush
- uva 1608 non-boring sequences不无聊的序列
ilikepp
题目DescriptionWewereafraidofmakingthisproblemstatementtooboring,sowedecidedtokeepitshort.Asequenceiscallednon-boringifitseveryconnectedsubsequencecontainsauniqueelement,i.e.anelementsuchthatnootherelem
- UVA - 1608 Non-boring sequences
wwyy9
分治法
Non-boringsequencesWewereafraidofmakingthisproblemstatementtooboring,sowedecidedtokeepitshort.Asequenceiscallednon-boringifitseveryconnectedsubsequencecontainsauniqueelement,i.e.anelementsuchthatnooth
- UVa OJ 1608 - Non-boring sequences
Yuukidach
UVaOJ
UVaOJ1608-Non-boringsequencesProblemAsequenceiscallednon-boringifitseveryconnectedsubsequencecontainsauniqueelement,i.e.anelementsuchthatnootherelementofthatsubsequencehasthesamevalue. Givenasequence
- bzoj4059【Cerc2012】Non-boring sequences
AaronGZK
分治bzoj
4059:[Cerc2012]Non-boringsequencesTimeLimit: 10Sec MemoryLimit: 128MBSubmit: 397 Solved: 141[Submit][Status][Discuss]Description我们害怕把这道题题面搞得太无聊了,所以我们决定让这题超短。一个序列被称为是不无聊的,仅当它的每个连续子序列存在一个独一无二的数字,即每个子序
- [扫描线 线段树 暴力] BZOJ 4059 [Cerc2012]Non-boring sequences
u014609452
扫描线:http://blog.csdn.net/PoPoQQQ/article/details/46380617暴力大法好:http://blog.csdn.net/geotcbrl/article/details/49797889定义lasti表示第i个元素上一次出现的位置(第一次出现则为0),nexti表示第i个元素下一次出现的位置(最后一次出现则为n+1),那么这个元素能成为某个区间仅出现
- 不无聊的序列(Non-boring sequences,Bzoj4059,CERC2012)
XY20130630
分治
AC通道:http://www.lydsy.com/JudgeOnline/problem.php?id=4059不无聊的序列Description我们害怕把这道题题面搞得太无聊了,所以我们决定让这题超短。一个序列被称为是不无聊的,仅当它的每个连续子序列存在一个独一无二的数字,即每个子序列里至少存在一个数字只出现一次。给定一个整数序列,请你判断它是不是不无聊的。Input第一行一个正整数T,表示有
- UVA 1608 Non-boring sequences (递归分治)
qq_21057881
题解:小白上的题,如果一个序列的任意连续子序列中至少有一个只出现一次的元素,则称这个序列是不无聊的,输入一个n(n
#include
#include
#include
usingnamespacestd;
constintMAX=200010;
intN,T;
inta[MAX],l[MAX],r[MAX];
boolsolve(intleft,intright)
{
if(left>=
- 【bzoj4059】[Cerc2012]Non-boring sequences 分治
u012288458
好吧,这道题的复杂度真是蛮神奇的。http://whx991201.is-programmer.com/posts/190036.html搞了好久才发现暴力的复杂度是对的。首先处理出pre[i],nxt[i],很明显只要i这个位置的数如果pre[i]R那么这个数在区间[L,R]上只出现了一次。考虑如果要检验区间[l,r],那么只需要找到一个在[l,r]上只出现了一次的数,然后把序列分成两部分分别检
- UVA 1608 Non-boring sequences
spongewxy
UVA
ewereafraidofmakingthisproblemstatementtooboring,sowedecidedtokeepitshort.Asequenceiscallednon-boringifitseveryconnectedsubsequencecontainsauniqueelement,i.e.anelementsuchthatnootherelementofthatsubse
- UVA 1608 Non-boring sequences
__560
#include
#defineREP(i,a,b)for(inti=a;ipos;
booljudge(intl,intr)
{
if(l>=r)return1;
//coutr){
nex=li;break;
}
li++;
}
else{
if(L[ri]r){
nex=ri;break;
}
ri--;
}
tag^=1;
}
if(nex==0)r
- 【bzoj4059】[Cerc2012]Non-boring sequences
GEOTCBRL
线段树大暴力
感觉这题A得比较奇怪。。。首先有一个很直接的想法是,对于一个点i,它所在的单独区间是[prei,nxti],那么它将对[prei,i−1]与[i+1,nxti]的点的答案产生影响。如果把每个产生影响的区间看做一个点,那么每个点i的影响就可以看做一个矩阵。显然就是看这些矩阵的并是否覆盖所有点。写了之后发现WA了==懒得调==然后改了个奇怪的暴力居然就A了然而复杂度似乎不太对呢。。同样对于一个区间[p
- 【bzoj4059】[Cerc2012]Non-boring sequences
GEOTCBRL
感觉这题A得比较奇怪。。。首先有一个很直接的想法是,对于一个点i,它所在的单独区间是[prei,nxti],那么它将对[prei,i−1]与[i+1,nxti]的点的答案产生影响。如果把每个产生影响的区间看做一个点,那么每个点i的影响就可以看做一个矩阵。显然就是看这些矩阵的并是否覆盖所有点。写了之后发现WA了==懒得调==然后改了个奇怪的暴力居然就A了然而复杂度似乎不太对呢。。同样对于一个区间[p
- UVa 1608,Non-boring sequences
sequence
好诡异的一个题啊
紫书上关于从左边找还是从两边往中间找的讨论没有看懂,怎么一下就找到唯一的元素了(⊙_⊙?)
方法就是用的书上讲的方法,类似于uva 11572,不过这个题需要预处理存下两边的最近的相同数的位置
for (int i=1;i<=n;i++) {
prev[i]=r[a[i]];
next[prev[i]]=i;
- BZOJ 4059: [Cerc2012]Non-boring sequences ( )
sequence
要快速在一段子序列中判断一个元素是否只出现一次 , 我们可以预处理出每个元素左边和右边最近的相同元素的位置 , 这样就可以 O( 1 ) 判断.
考虑一段序列 [ l , r ] , 假如我们找到了序列中唯一元素的位置 p , 那我们只需检查 [ l , p - 1 ] & [ p + 1 , r ] 是否 non-boring 即可 .
如何检查 序列 [ l , r
- UVa 1608 (分治 中途相遇) Non-boring sequences
sequence
预处理一下每个元素左边和右边最近的相邻元素。
对于一个区间[l, r]和区间内某一个元素,这个元素在这个区间唯一当且仅当左右两边最近的相邻元素不在这个区间内。这样就可以O(1)完成查询。
首先查找整个字符串是否有唯一元素,如果没有则整个序列是无聊的。
有的话,假设这个唯一元素下标是p,那么如果子序列[0, p-1]和[p+1, n-1]是不无聊的,那么这个序列就是不无聊的。
- uva 1608 - Non-boring sequences
LuckyqXd
Wewereafraidofmakingthisproblemstatementtooboring,sowedecidedtokeepitshort.Asequenceiscallednon-boringifitseveryconnectedsubsequencecontainsauniqueelement,i.e.anelementsuchthatnootherelementofthatsubs
- 1608 - Non-boring sequences(折半递归。。暂且这么叫吧)
weizhuwyzc000
递归ACMuva
该题给一个序列,让我们判断是不是不无聊序列(如果不明白请看样例),我们可以将区间从大到小不断压缩来确定答案,首先要确定一个区间是否满足要求,只要看这个区间里是不是有一个只出现一次的数,受前面《唯一的雪花》一题的启发,我们可以在O(n)时间内求出当前数离他最近的与他相同的数的位置,用数组保存,那么可以在O(1)的时间快速判断,这样就将时间复杂度降到O(n^2)但是这样还是不够的,会超时。 紫书上给出
- BZOJ 4059 Cerc2012 Non-boring sequences 线段树+扫描线
PoPoQQQ
线段树扫描线bzojBZOJ4059
题目大意:定义一个序列为【不无聊的】当且仅当这个序列的任意一个区间都存在一个数只出现过一次,给定一个序列,要求判断这个序列是否是【不无聊的】定义lasti表示第i个元素上一次出现的位置(第一次出现则为0),nexti表示第i个元素下一次出现的位置(最后一次出现则为n+1),那么这个元素能成为某个区间仅出现一次的数,当且仅当这个区间的左端点在[lasti+1,i]之间,右端点在[i,nexti−1]
- BZOJ 4059 Cerc2012 Non-boring sequences 线段树+扫描线
PoPoQQQ
线段树扫描线bzojBZOJ4059
题目大意:定义一个序列为【不无聊的】当且仅当这个序列的任意一个区间都存在一个数只出现过一次,给定一个序列,要求判断这个序列是否是【不无聊的】定义lasti表示第i个元素上一次出现的位置(第一次出现则为0),nexti表示第i个元素下一次出现的位置(最后一次出现则为n+1),那么这个元素能成为某个区间仅出现一次的数,当且仅当这个区间的左端点在[lasti+1,i]之间,右端点在[i,nexti−1]
- 【高效算法设计——递归】 UVa 1608 Non-boring sequences
LosinueriS
ACM
题意:给定一段序列,如果这段序列的任意连续子序列中至少存在一个数唯一,那么这段序列就是Non-boring,否则就是boring,判定这段序列是否boring思路:如果一个数A[x]是全场唯一,那么我们只需判断A[1]~A[x-1]和A[x+1]~A[n]是否满足要求,为什么呢?因为A[x]全场唯一,所以经过A[x]的连续字段必然是Non-boring的,所以我们可以设计一个递归函数boolisB
- CERC2012 D - Non-boring sequences 暴力
kk303
思维
题目:Clickhere题意:一个数列是non-boring只有其所有长度>1的子串中至少有一个数字仅出现了一次...长度可能会到2*10^5..现在给出若干的序列..请判断是否为non-boring序列...题解:可以用O(nlogn)预处理..得到串中每一位数可以覆盖到的最左与最右(仅出现一次)...然后就是利用dfs..一层一层的判断了...无语的是我在枚举终点的时候是从s~e..超时到吐.
- CERC2012 D - Non-boring sequences 暴力
kk303
题目: Clickhere 题意: 一个数列是non-boring只有其所有长度>1的子串中至少有一个数字仅出现了一次...长度可能会到2*10^5..现在给出若干的序列..请判断是否为non-boring序列... 题解: 可以用O(nlogn)预处理..得到串中每一位数可以覆盖到的最左与最右(仅
- UVALive 6258 Non-boring sequences 分治
CHCXCHC
分治
题意:给一个长度为n的序列(n≤200000),判断这个序列是不是无聊序列,若该序列中的任意连续子序列中存在一个数是唯一的,也就是只出现一次,那么这个序列就是非无聊子序列。求第i个位置和它两边最近的下一个相同数的位置,对于任意长度的连续子序列[L,R],一定要有X使得pre[X]R成立,那么就可以将这个子序列分开为[L,X−1]和[X+1,R]以此判断。注意要从两边开始扫,如果值从一边开始扫可能退
- html页面js获取参数值
0624chenhong
html
1.js获取参数值js
function GetQueryString(name)
{
var reg = new RegExp("(^|&)"+ name +"=([^&]*)(&|$)");
var r = windo
- MongoDB 在多线程高并发下的问题
BigCat2013
mongodbDB高并发重复数据
最近项目用到 MongoDB , 主要是一些读取数据及改状态位的操作. 因为是结合了最近流行的 Storm进行大数据的分析处理,并将分析结果插入Vertica数据库,所以在多线程高并发的情境下, 会发现 Vertica 数据库中有部分重复的数据. 这到底是什么原因导致的呢?笔者开始也是一筹莫 展,重复去看 MongoDB 的 API , 终于有了新发现 :
com.mongodb.DB 这个类有
- c++ 用类模版实现链表(c++语言程序设计第四版示例代码)
CrazyMizzz
数据结构C++
#include<iostream>
#include<cassert>
using namespace std;
template<class T>
class Node
{
private:
Node<T> * next;
public:
T data;
- 最近情况
麦田的设计者
感慨考试生活
在五月黄梅天的岁月里,一年两次的软考又要开始了。到目前为止,我已经考了多达三次的软考,最后的结果就是通过了初级考试(程序员)。人啊,就是不满足,考了初级就希望考中级,于是,这学期我就报考了中级,明天就要考试。感觉机会不大,期待奇迹发生吧。这个学期忙于练车,写项目,反正最后是一团糟。后天还要考试科目二。这个星期真的是很艰难的一周,希望能快点度过。
- linux系统中用pkill踢出在线登录用户
被触发
linux
由于linux服务器允许多用户登录,公司很多人知道密码,工作造成一定的障碍所以需要有时踢出指定的用户
1/#who 查出当前有那些终端登录(用 w 命令更详细)
# who
root pts/0 2010-10-28 09:36 (192
- 仿QQ聊天第二版
肆无忌惮_
qq
在第一版之上的改进内容:
第一版链接:
http://479001499.iteye.com/admin/blogs/2100893
用map存起来号码对应的聊天窗口对象,解决私聊的时候所有消息发到一个窗口的问题.
增加ViewInfo类,这个是信息预览的窗口,如果是自己的信息,则可以进行编辑.
信息修改后上传至服务器再告诉所有用户,自己的窗口
- java读取配置文件
知了ing
1,java读取.properties配置文件
InputStream in;
try {
in = test.class.getClassLoader().getResourceAsStream("config/ipnetOracle.properties");//配置文件的路径
Properties p = new Properties()
- __attribute__ 你知多少?
矮蛋蛋
C++gcc
原文地址:
http://www.cnblogs.com/astwish/p/3460618.html
GNU C 的一大特色就是__attribute__ 机制。__attribute__ 可以设置函数属性(Function Attribute )、变量属性(Variable Attribute )和类型属性(Type Attribute )。
__attribute__ 书写特征是:
- jsoup使用笔记
alleni123
java爬虫JSoup
<dependency>
<groupId>org.jsoup</groupId>
<artifactId>jsoup</artifactId>
<version>1.7.3</version>
</dependency>
2014/08/28
今天遇到这种形式,
- JAVA中的集合 Collectio 和Map的简单使用及方法
百合不是茶
listmapset
List ,set ,map的使用方法和区别
java容器类类库的用途是保存对象,并将其分为两个概念:
Collection集合:一个独立的序列,这些序列都服从一条或多条规则;List必须按顺序保存元素 ,set不能重复元素;Queue按照排队规则来确定对象产生的顺序(通常与他们被插入的
- 杀LINUX的JOB进程
bijian1013
linuxunix
今天发现数据库一个JOB一直在执行,都执行了好几个小时还在执行,所以想办法给删除掉
系统环境:
ORACLE 10G
Linux操作系统
操作步骤如下:
第一步.查询出来那个job在运行,找个对应的SID字段
select * from dba_jobs_running--找到job对应的sid
&n
- Spring AOP详解
bijian1013
javaspringAOP
最近项目中遇到了以下几点需求,仔细思考之后,觉得采用AOP来解决。一方面是为了以更加灵活的方式来解决问题,另一方面是借此机会深入学习Spring AOP相关的内容。例如,以下需求不用AOP肯定也能解决,至于是否牵强附会,仁者见仁智者见智。
1.对部分函数的调用进行日志记录,用于观察特定问题在运行过程中的函数调用
- [Gson六]Gson类型适配器(TypeAdapter)
bit1129
Adapter
TypeAdapter的使用动机
Gson在序列化和反序列化时,默认情况下,是按照POJO类的字段属性名和JSON串键进行一一映射匹配,然后把JSON串的键对应的值转换成POJO相同字段对应的值,反之亦然,在这个过程中有一个JSON串Key对应的Value和对象之间如何转换(序列化/反序列化)的问题。
以Date为例,在序列化和反序列化时,Gson默认使用java.
- 【spark八十七】给定Driver Program, 如何判断哪些代码在Driver运行,哪些代码在Worker上执行
bit1129
driver
Driver Program是用户编写的提交给Spark集群执行的application,它包含两部分
作为驱动: Driver与Master、Worker协作完成application进程的启动、DAG划分、计算任务封装、计算任务分发到各个计算节点(Worker)、计算资源的分配等。
计算逻辑本身,当计算任务在Worker执行时,执行计算逻辑完成application的计算任务
- nginx 经验总结
ronin47
nginx 总结
深感nginx的强大,只学了皮毛,把学下的记录。
获取Header 信息,一般是以$http_XX(XX是小写)
获取body,通过接口,再展开,根据K取V
获取uri,以$arg_XX
&n
- 轩辕互动-1.求三个整数中第二大的数2.整型数组的平衡点
bylijinnan
数组
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
public class ExoWeb {
public static void main(String[] args) {
ExoWeb ew=new ExoWeb();
System.out.pri
- Netty源码学习-Java-NIO-Reactor
bylijinnan
java多线程netty
Netty里面采用了NIO-based Reactor Pattern
了解这个模式对学习Netty非常有帮助
参考以下两篇文章:
http://jeewanthad.blogspot.com/2013/02/reactor-pattern-explained-part-1.html
http://gee.cs.oswego.edu/dl/cpjslides/nio.pdf
- AOP通俗理解
cngolon
springAOP
1.我所知道的aop 初看aop,上来就是一大堆术语,而且还有个拉风的名字,面向切面编程,都说是OOP的一种有益补充等等。一下子让你不知所措,心想着:怪不得很多人都和 我说aop多难多难。当我看进去以后,我才发现:它就是一些java基础上的朴实无华的应用,包括ioc,包括许许多多这样的名词,都是万变不离其宗而 已。 2.为什么用aop&nb
- cursor variable 实例
ctrain
variable
create or replace procedure proc_test01
as
type emp_row is record(
empno emp.empno%type,
ename emp.ename%type,
job emp.job%type,
mgr emp.mgr%type,
hiberdate emp.hiredate%type,
sal emp.sal%t
- shell报bash: service: command not found解决方法
daizj
linuxshellservicejps
今天在执行一个脚本时,本来是想在脚本中启动hdfs和hive等程序,可以在执行到service hive-server start等启动服务的命令时会报错,最终解决方法记录一下:
脚本报错如下:
./olap_quick_intall.sh: line 57: service: command not found
./olap_quick_intall.sh: line 59
- 40个迹象表明你还是PHP菜鸟
dcj3sjt126com
设计模式PHP正则表达式oop
你是PHP菜鸟,如果你:1. 不会利用如phpDoc 这样的工具来恰当地注释你的代码2. 对优秀的集成开发环境如Zend Studio 或Eclipse PDT 视而不见3. 从未用过任何形式的版本控制系统,如Subclipse4. 不采用某种编码与命名标准 ,以及通用约定,不能在项目开发周期里贯彻落实5. 不使用统一开发方式6. 不转换(或)也不验证某些输入或SQL查询串(译注:参考PHP相关函
- Android逐帧动画的实现
dcj3sjt126com
android
一、代码实现:
private ImageView iv;
private AnimationDrawable ad;
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout
- java远程调用linux的命令或者脚本
eksliang
linuxganymed-ssh2
转载请出自出处:
http://eksliang.iteye.com/blog/2105862
Java通过SSH2协议执行远程Shell脚本(ganymed-ssh2-build210.jar)
使用步骤如下:
1.导包
官网下载:
http://www.ganymed.ethz.ch/ssh2/
ma
- adb端口被占用问题
gqdy365
adb
最近重新安装的电脑,配置了新环境,老是出现:
adb server is out of date. killing...
ADB server didn't ACK
* failed to start daemon *
百度了一下,说是端口被占用,我开个eclipse,然后打开cmd,就提示这个,很烦人。
一个比较彻底的解决办法就是修改
- ASP.NET使用FileUpload上传文件
hvt
.netC#hovertreeasp.netwebform
前台代码:
<asp:FileUpload ID="fuKeleyi" runat="server" />
<asp:Button ID="BtnUp" runat="server" onclick="BtnUp_Click" Text="上 传" />
- 代码之谜(四)- 浮点数(从惊讶到思考)
justjavac
浮点数精度代码之谜IEEE
在『代码之谜』系列的前几篇文章中,很多次出现了浮点数。 浮点数在很多编程语言中被称为简单数据类型,其实,浮点数比起那些复杂数据类型(比如字符串)来说, 一点都不简单。
单单是说明 IEEE浮点数 就可以写一本书了,我将用几篇博文来简单的说说我所理解的浮点数,算是抛砖引玉吧。 一次面试
记得多年前我招聘 Java 程序员时的一次关于浮点数、二分法、编码的面试, 多年以后,他已经称为了一名很出色的
- 数据结构随记_1
lx.asymmetric
数据结构笔记
第一章
1.数据结构包括数据的
逻辑结构、数据的物理/存储结构和数据的逻辑关系这三个方面的内容。 2.数据的存储结构可用四种基本的存储方法表示,它们分别是
顺序存储、链式存储 、索引存储 和 散列存储。 3.数据运算最常用的有五种,分别是
查找/检索、排序、插入、删除、修改。 4.算法主要有以下五个特性:
输入、输出、可行性、确定性和有穷性。 5.算法分析的
- linux的会话和进程组
网络接口
linux
会话: 一个或多个进程组。起于用户登录,终止于用户退出。此期间所有进程都属于这个会话期。会话首进程:调用setsid创建会话的进程1.规定组长进程不能调用setsid,因为调用setsid后,调用进程会成为新的进程组的组长进程.如何保证? 先调用fork,然后终止父进程,此时由于子进程的进程组ID为父进程的进程组ID,而子进程的ID是重新分配的,所以保证子进程不会是进程组长,从而子进程可以调用se
- 二维数组 元素的连续求解
1140566087
二维数组ACM
import java.util.HashMap;
public class Title {
public static void main(String[] args){
f();
}
// 二位数组的应用
//12、二维数组中,哪一行或哪一列的连续存放的0的个数最多,是几个0。注意,是“连续”。
public static void f(){
- 也谈什么时候Java比C++快
windshome
javaC++
刚打开iteye就看到这个标题“Java什么时候比C++快”,觉得很好笑。
你要比,就比同等水平的基础上的相比,笨蛋写得C代码和C++代码,去和高手写的Java代码比效率,有什么意义呢?
我是写密码算法的,深刻知道算法C和C++实现和Java实现之间的效率差,甚至也比对过C代码和汇编代码的效率差,计算机是个死的东西,再怎么优化,Java也就是和C