775. 山海经 ★★★ 输入文件:
hill.in
输出文件:
hill.out
简单对比
时间限制:1 s 内存限制:128 MB
【问题描述】
“南山之首日鹊山。其首日招摇之山,临于西海之上,多桂,多金玉。有草焉,其状如韭而青华,其名日祝余,食之不饥……又东三百里,日堂庭之山,多棪木,多白猿,多水玉,多黄金。
又东三百八十里,日猨翼之山,其中多怪兽,水多怪鱼,多白玉,多蝮虫,多怪蛇,名怪木,不可以上。……”
《山海经》是以山为纲,以海为线记载古代的河流、植物、动物及矿产等情况,而且每一条记录路线都不会有重复的山出现。某天,你的地理老师想重游《山海经》中的路线,为了简化问题,老师已经把每座山用一个整数表示他对该山的喜恶程度,他想知道第a座山到第b座山的中间某段路(i,j)。能使他感到最满意,即(i,j)这条路上所有山的喜恶度之和是(c,d)(a≤c≤d≤b)最大值。于是老师便向你请教,你能帮助他吗?值得注意的是,在《山海经》中,第i座山只能到达第i+1座山。
【输入】
输入第1行是两个数,n,m,2≤n≤100000,1≤m≤100000,n表示一共有n座山,m表示老师想查询的数目。
第2行是n个整数,代表n座山的喜恶度,绝对值均小于10000。
以下m行每行有a,b两个数,1≤a≤j≤b≤m,表示第a座山到第b座山。
【输出】
一共有m行,每行有3个数i,j,s,表示从第i座山到第j座山总的喜恶度为s。显然,对于每个查询,有a≤i≤j≤b,如果有多组解,则输出i最小的,如果i也相等,则输出j最小的解。
【输入样例】
5 3
5 -6 3 -1 4
1 3
1 5
5 5
【输出样例】
1 1 5
3 5 6
5 5 4
正解为线段树。题意大概为求区间最长连续和。
首先,考虑结果的来源只有三个地方,区间前缀,区间后缀和区间的中间,所以要维护这三个变量,答案就是三者之一。 定义四个变量sum,lmax,rmax,ma,分别表示区间和,最大前缀和,最大 后缀和,最大 中间和。为了维护询问的左右边界,定义lpos为区间最大 前缀和的右边界,rpos为区间 最大后 缀和的左边界,ml,mr为中间和的左右边界。那么很容易想到以下合并方法
(z为当前节点,lch,rch分别为左右子节点)
1. tr[z].lmax=max(tr[lch].lmax,tr[lch].sum+tr[rch].lmax);
2. tr[z].rmax=max(tr[rch].rmax,tr[rch].sum+tr[lch].rmax);
3. tr[z].ma=max(tr[lch].ma,tr[rch].ma,tr[lch].rmax+tr[rch].lmax);
在维护值时同时把下标维护(注意大小相同时按题目要求处理,因为这WA了2次)
接下来是查询,我们可以换一下思路,把以往线段树查询的点换为一条线段,那么这条线段就可以用上面的三种方法维护,最终结果就是你查询得到的那条线段的lmax,rmax,ma的最大值。
#include
#define maxn 400005
using namespace std;
int n,m,inf=0xfffffff;
struct tree{int lc,rc,sum,lmax,rmax,ma,lpos,rpos,ml,mr;tree(){lmax=rmax=ma=-inf;sum=0;}}tr[maxn];
void pushup(int x)
{
int lch=x<<1,rch=lch|1;
tr[x].sum=tr[lch].sum+tr[rch].sum;
if(tr[lch].lmax>1,lch=z<<1,rch=lch|1;
build(x,mid,lch);build(mid+1,y,rch);
pushup(z);
}
tree query(int x,int y,int z)
{
if(tr[z].lc>=x&&tr[z].rc<=y)
return tr[z];
int mid=tr[z].lc+tr[z].rc>>1,lch=z<<1,rch=lch|1;tree t1,t2,t3;
if(x<=mid) t1=query(x,y,lch);
if(mid=x.rmax)
{
if(x.lmax>=x.ma) printf("%d %d %d\n",x.lc,x.lpos,x.lmax);
else printf("%d %d %d\n",x.ml,x.mr,x.ma);
}
else if(x.rmax>x.ma) printf("%d %d %d\n",x.rpos,x.rc,x.rmax);
else printf("%d %d %d\n",x.ml,x.mr,x.ma);
}
int main()
{
freopen("hill.in","r",stdin);
freopen("hill.out","w",stdout);
scanf("%d%d",&n,&m);
build(1,n,1);int x,y;
for(int i=1;i<=m;i++)
{
scanf("%d%d",&x,&y);
tree tmp=query(x,y,1);
print(tmp);
}
return 0;
}
你可能感兴趣的:(线段树)
论当今的精神状态...(2025.3.14)
VU-zFaith870
日常随笔 模拟退火算法
好无聊好烦喏,字符串、线段树、深搜宽搜、DP还有数论...无语。最近OI那边又有西安多校集训的消息,13天的集训,多少是长点。不去是OI的溃败,去了就是whk的惨退。挺纠结,跟家长聊聊吧,大抵是不同意i,我也不打算去,现在OI是有点紧张,但文化成绩别退啊,很难受...我还是习惯在学校安然自得地静心学习,闲暇时放松身心,焦虑时做些心理工作(去找心理老师不错),迷茫时还有身边的一切。因为我眷恋这里..
区间信息操作神器:线段树原理详解
xiaoyu❅
# 树上操作 高级数据结构 # 区间信息操作 算法 数据结构 java
目录一、什么是线段树?二、线段树的核心特性三、线段树的实现原理1.存储结构2.索引计算3.区间划分示例(数组[1,3,5,7,9,11])四、线段树操作详解1.构建线段树(Build)2.区间查询(Query)3.单点更新(Update)五、Java实现代码(区间和查询)六、线段树优化技巧1.延迟传播(LazyPropagation)2.动态开点七、线段树vs其他数据结构八、经典应用场景九、总结一
十年OI一场空,不开long long见祖宗
xiyuping24
题解 算法 gradle tag icpc 程序设计 docker
//线段树:单点修改+区间求和#include#definellunsignedlonglongusingnamespacestd;lln,m,a[1000010],ans[2000010],tag[2000010];llls(llx){returnx>1;lazy(ls(k),l,mid,tag[k]);lazy(rs(k),mid+1,r,tag[k]);tag[k]=0;}voidbuild
线段树学习札记
Cool_(wly)_Dino
学习 数据结构 算法 c++
线段树维护序列的树形数据结构——线段树面对以下问题luoguP3372,给出一个数列:(1)将区间【x,y】内每一个数加上k(2)求出某个区间【x,y】中每一个数的和。虽然普通方法修改复杂度O(1)但是求和的效率却是O(n)线段树的思想个人来讲就是归并,线段树所维护的信息必须具有可合并性,个人认为其实现原理过于基础,不做分析。一些有意思的证明:对于节点数为n深度为h的一棵树,其深度可以表示为(n+
洛谷模板汇整
Alaso_shuang
算法分类 算法
普及-P3378【模板】堆P3367【模板】并查集P1177【模板】快速排序P3383【模板】线性筛素数P3370【模板】字符串哈希P3366【模板】最小生成树P1226【模板】快速幂||取余运算普及/提高-P3385【模板】负环P3865【模板】ST表P8306【模板】字典树P5788【模板】单调栈P3811【模板】乘法逆元P4549【模板】裴蜀定理P3372【模板】线段树1P3382【模板】三
树状数组(二叉索引树)
椰萝Yerosius
板子 数据结构 算法
树状数组(二叉索引树)树状数组的核心思想:分治。将数组以二叉树的逻辑结构进行组织。树状数组巧妙的利用了下标的二进制特性,以维护区间信息。树状数组并非一棵真正的二叉树,以二叉树的存储结构进行组织的为线段树。lowbit\texttt{lowbit}lowbit操作:获取整数最低位的1的位置。由于0的lowbit\texttt{lowbit}lowbit没有意义,因此树状数组下标需从1开始。intlo
研究线段树的最大子段和
数据掘金
java 算法 数据库
我们可以分析出上题就是带修改的最大子段和[-](http://jvquant.com/wiki/行情/解析行情.html)遇到这种类型的题目应该想到用线段树[-](http://jvquant.com/wiki/行情/订阅/美股行情订阅.html)实现对于原数列,先建起一棵线段树,每个节点包含最大前缀、最大后缀、最大字段和、区间和信息[-]()当你明确一道题是线段树时,要先思考pushup和pus
【封印宝石——线段树】
Kent_J_Truman
蓝桥杯 算法
题目分析封印宝石题解https://www.acwing.com/solution/content/261922/代码#includeusingnamespacestd;usingpll=pair;#definexfirst#defineysecondconstintN=1e5+10;structnode{intl,r;intv1,v2;inti1,i2;}tr[4*N];intn,k,a[N],
一些关于数据结构的杂谈
超闻逸事
算法 c++ 算法 笔记 数据结构
树链剖分P3384【模板】轻重链剖分/树链剖分作用维护树上路径的相关信息。常与线段树相结合。性质所有节点都属于且仅属于一条重链,重链将树完全剖分。重链与子树内的dfs\texttt{dfs}dfs序连续。【这一个性质非常有用】每一条路径最多被拆分成logn\lognlogn条重链(向下经过一条轻边时,子树大小至少除以222)。一些定义f[x]节点xxx的父亲。sz[x]节点xxx对应的子树大小。
Leetcode3165:不包含相邻元素子序列的最大和
ʚ发什么呆^ɞ
算法 数据结构
代码思路这段代码实现了一个特殊类型的线段树(SegmentTree),用于解决一类特定的动态规划问题,具体来说,是求解一系列更新操作后,一个特定子序列和的最大值问题。这里的子序列和受到一些特定的约束条件影响,这些条件通过线段树的节点(SegNode)中的四个值(v00,v01,v10,v11)来体现。以下是对代码思路的详细解释:数据结构定义SegNode结构体:包含四个longlong类型的成员变
XVIII Open Cup named after E.V. Pankratiev. GP of Urals
weixin_33738578
ui
A.Nutella’sLife斜率优化DP显然,CDQ分治后按$a$排序建线段树,每层维护凸包,查询时不断将队首弹出即可。时间复杂度$O(n\log^2n)$。#include#includeusingnamespacestd;typedeflonglongll;typedefpairP;constintN=100010,M=262150;intn,i,a[N],cb;llf[N],g[N],w[
Nutella’s Life-斜率优化+线段树
bensanhuan
题解 动态规划 数据结构
如有疏漏错误之处,请多指教题意codeforce.com发布了未来一年的比赛列表。未来一年将会有n(1≤n≤105)n(1\leqn\leq10^{5})n(1≤n≤105)场比赛。小红为每场比赛计算了一个快乐值a[i](10−9≤a[i]≤109)a[i](10^{-9}\leqa[i]\leq10^{9})a[i](10−9≤a[i]≤109)。小红参加比赛的规则和快乐值获取规则如下:如果小红
深入解析线段树-构建原理与区间查询优化
一键难忘
算法之翼 算法 线段树 动态规划 宽度优先 深度优先
本文收录于专栏:算法之翼深入解析线段树-构建原理与区间查询优化线段树(SegmentTree)是一种高级数据结构,常用于处理区间查询与动态更新问题。在许多应用中,例如数组的区间和查询,区间最值查询,线段树都能够提供高效的解决方案。本文将深入探讨线段树的构建原理,并结合实际代码示例,讨论如何优化区间查询。1.线段树的基本原理线段树是一棵二叉树,每个节点对应数组的一个区间。叶节点存储数组的单个元素,内
线段树知识点总结和学习心得分享
GA_PK
线段树主要用来维护复杂的区间信息.只要满足区间可加性,线段树基本都可以解决.1.线段树基本操作(单点更新,区间求和等不涉及lazy标记问题)先来讲建树问题,线段树建树有很多种方法,本文介绍的是把一个区间划分成为[l,mid],[mid+1,r]的建树方法.我们会把一个大区间分成若干个小区间,tree[1]是表示整个大区间.把它分成两个小区间.用下标tree[2×father],tree[2×fat
7.3.6 蓝桥杯基础数据结构之线段树维护哈希
夏驰和徐策
蓝桥杯 哈希算法 数据结构 蓝桥杯 线段树
7.3.6蓝桥杯基础数据结构之线段树维护哈希引言在编程竞赛和算法设计中,线段树是处理区间问题的强大工具。结合哈希,线段树可以高效地处理字符串和其他序列数据的复杂查询。本文将探讨如何在蓝桥杯等编程竞赛中使用线段树维护哈希值。基础概念线段树线段树是一种二叉树结构,用于高效处理区间相关的查询和更新操作。它将一个区间分割成更小的子区间,使得对这些子区间的操作更加高效。哈希哈希在处理字符串和序列数据时尤为重
模板分享:线段树(1)
pystraf
数据结构与算法 # 数据结构 算法 数据结构 c++ 线段树
Code先放代码templatestructsegment{private:#definels(u*2+1)#definers(u*2+2)structNode{intl,r;Infoinfo;};vectortr;public:usinginfo_type=Info;segment(){}segment(intn,Infov=Info()){vectora(n,v);init(a);}templ
模板分享:线段树(2)
pystraf
数据结构与算法 # 数据结构 c++ 算法 数据结构 线段树
Code先放代码:#include#includeusingnamespacestd;templatestructlazy_segment{private:#definels(u*2+1)#definers(u*2+2)structNode{intl,r;Infoinfo;Tagtag;};vectortr;public:usinginfo_type=Info;usingtag_type=Tag;
洛谷P3372 【模板】线段树 1
xwztdas
数据结构
洛谷题目传送门题目描述如题,已知一个数列,你需要进行下面两种操作:将某区间每一个数加上k。求出某区间每一个数的和。输入格式第一行包含两个整数,,分别表示该数列数字的个数和操作的总个数。第二行包含个用空格分隔的整数,其中第个数字表示数列第项的初始值。接下来行每行包含3或4个整数,表示一个操作,具体如下:1xyk:将区间[,]内每个数加上k。2xy:输出区间[,]内每个数的和。输出格式输出包含若干行整
「分块」数列分块入门1 – 9 by hzwer 解题记录
GA_PK
出处学习蓝书的时候感觉书上关于分块的题目太少了.而且都是难度较大的一些分块题目,想巩固一下分块方面的知识,就找到了hzwer大佬的分块入门知识介绍.用这篇博客记录一下.从树状数组到线段树再到分块.都是对区间信息的快速处理来达到想要的效果.树状数组效率最优,可是拓展性实在不高.线段树效率稍微差一点但是拓展性较好,可是在信息不满足区间可加性的情况下代码难度会高很多.而分块效率上最差但是可以接受,且拓展
洛谷 P3372:线段树 1 ← 分块算法模板(区间更新、区间查询)
hnjzsyjyj
信息学竞赛 # 分治算法与双指针 分块
【题目来源】https://www.luogu.com.cn/problem/P3372【题目描述】如题,已知一个数列,你需要进行下面两种操作:(1)将某区间每一个数加上k。(2)求出某区间每一个数的和。【输入格式】第一行包含两个整数n,m,分别表示该数列数字的个数和操作的总个数。第二行包含n个用空格分隔的整数,其中第i个数字表示数列第i项的初始值。接下来m行每行包含3或4个整数,表示一个操作,具
分块算法详解
justin666888
C++ 数据结构 C++算法 数据结构 关键字 数据结构 算法
分块算法详解一.啥是分块二.分块的操作1.分组2.区间加法&单点查询3.区间加法&询问区间内小于某个值x的元素个数4.区间求和&区间加法5.区间开方&区间求和6.单点插入&单点询问7.区间加法&区间前驱8.区间乘法&区间加法&单点询问9.区间某值个数&区间赋值10.区间众数三.分块算法时间复杂度分析1.时间复杂度2.万恶的卡常四.分块算法与线段树对比五.例题一.啥是分块分块,顾名思义,就是把一个东
最好的线段树总结
QYitong
数据结构 c语言 ACM 数据结构线段树
线段树详解By岩之痕目录:一:综述二:原理三:递归实现四:非递归原理五:非递归实现六:线段树解题模型七:扫描线八:可持久化(主席树)九:练习题一:综述假设有编号从1到n的n个点,每个点都存了一些信息,用[L,R]表示下标从L到R的这些点。线段树的用处就是,对编号连续的一些点进行修改或者统计操作,修改和统计的复杂度都是O(log2(n)).线段树的原理,就是,将[1,n]分解成若干特定的子区间(数量
[线段树(猫树)] 最大连续和
Jcqsunny
算法 c++ 线段树 猫树
题目描述给出一个含有NNN个结点的环,编号分别为1…N1\ldotsN1…N,环上的点带有权值(可正可负),现要动态的修改某个点的权值,求每次修改后环上的最大连续和,但不能是整个序列的和。输入格式第一行为一个整数NNN。第二行为NNN个用空格分开的整数。第三行为一个整数M(4≤M≤100000)M(4\leM\le100000)M(4≤M≤100000),表示修改的次数(绝对值小于等于100010
归并排序(Ologn)及其应用(求逆序对)+例题(后续仍有补充)
万般算法皆思想
这几天一直在看lrj紫书的归并排序部分,刚开始连递归都看不懂,,现在已经完全理解了,写这个bolg就是为了记录一下板子,方便以后进行记忆唤醒。之后陆续还会学习补充树状数组和线段树,这三者其实都是二分思想的应用,最关键的不是记住这个板子,而是能够理解其中的思想。归并排序又是分治法的一种应用,分为分和治两部分。分即为根据递归,将数组一直划分到只剩两个元素的时候,这个时候问题就很简单了,而治又是从两个元
在 MoonBit 实现线段树(二)
编程语言
引言在上一篇文章当中我们讨论了最基础线段树的实现,但那棵线段树只能做到区间的查询(当然单点的修改与查询也是可以的),但做不到区间的修改(一个经典的应用是区间加法,即整个区间都加上某个值)。在本节当中我们将基于上次的线段树继续加深抽象,引入LazyTag的概念来解决区间修改的问题,完成一棵功能基本完备的线段树。怎么做到区间修改?先设想如果我们在线段树上给一个区间都加上某个数会发生什么?或者换种说法,
编程实践|用 MoonBit 实现线段树(一)
编程语言
引言线段树(SegmentTree)是一种常见的数据结构,用于解决一些线性区间的修改、查询问题,比如对于问题:给出一个长度已知的、有初值的数字数组,接下来要进行许多区间加法操作(将一个区间的数值都加上某个值)和区间求和操作(求该区间数值的和并输出)如果该问题使用正常的数组方式来遍历求解,假设该数组长度为N,每次修改和查询的操作耗时是O(N)的;但线段树经过O(NlogN)的构建之后,可以对上述两个
BZOJ 五月胡乱补题
nike0good
其他 屯题 bzoj 博客补档
旧博客搬运部分格式还没来得及改T_T【BZOJ4806:炮】同BZOJ1801【BZOJ3242:[Noi2013]快餐店】树形dp,要么最远点在同一颗树上(dp),要么在不同树上,此时答案=去掉任何一条边后形成的树的答案的最小值,我们枚举去掉的那条边。由于答案=s[i]-s[j]+dis[i]+dis[j],i,j可以分开考虑,也可以用线段树解决。【BZOJ4878:[Lydsy2017年5月月
线段树(模板)
数学收藏家
线段树
#includeusingnamespacestd;#defineintlonglong#defineendl'\n'#defineIOSios::sync_with_stdio(false);cin.tie(0);cout.tie(0);#definemaxn100005intn,q;inta[maxn];structnode{intval,lazy;}s[maxn*4];voidpush_up
CCF-CSP认证考试(第32次)总结+题解
Romanticroom
算法
总结:这一次我选了时间较近的一次进行练习,结果有点悲,前两题就一个质因数分解还好,第三题我走了弯路,想通过类似线段树的手段处理,结果还差了系数,最后一个点tle了。。。第四题直接放弃了。。(太菜,没脸见人)第五题还抱有幻想,当然也只有幻想。。后两题只能打暴力了,以我现在水平,希望努力一个月能有所改变吧。题解:(这里只给到三题题解,再往后我也不会了。。)题一:仓库规划西西艾弗岛上共有n个仓库,依次编
数据结构入门(5)——树与二叉树的应用
Dusk Cteator
高级语言程序设计 数据结构 笔记 数据结构 算法 霍夫曼树 二叉树 c++
数据结构入门——树与二叉树的应用文章目录数据结构入门——树与二叉树的应用前言一、压缩与哈夫曼树扩充二叉树哈夫曼算法哈夫曼算法基本思想哈夫曼算法哈夫曼编码二、表达式树如何构造表达式二叉树计算表达式二叉树对应的值三、并查集并查集的实现四、初探线段树与树状数组线段树线段树操作树状数组定义操作树状数组和线段树前言本系列文章将简要介绍数据结构课程入门知识,文章将结合我们学校(吉大)数据结构课程内容进行讲述。
关于旗正规则引擎规则中的上传和下载问题
何必如此
文件下载 压缩 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 端口占用 spark master 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不折腾
finereport FAQ 报表软件
这里写点抛砖引玉,希望大家能把自己整理的问题及解决方法晾出来,Mark一下,利人利己。
出现问题先搜一下文档上有没有,再看看度娘有没有,再看看论坛有没有。有报错要看日志。下面简单罗列下常见的问题,大多文档上都有提到的。
1、repeated column width is largerthan paper width:
这个看这段话应该是很好理解的。比如做的模板页面宽度只能放
mysql 用户管理
墙头上一根草
linux mysql user
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
spring Spring 入门 Spring 实例 Spring3 Spring 教程
这个问题我实在是为整个 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转byte byte转int 基本数据类型的实现
在BMP文件和文件压缩时需要用到的int与byte转换,现将理解的贴出来;
主要是要理解;位移等概念 http://baihe747.iteye.com/blog/2078029
int转byte;
byte转int;
/**
* 字节转成int,int转成字节
* @author Administrator
*
简单模拟实现数据库连接池
bijian1013
java thread java多线程 简单模拟实现数据库连接池
简单模拟实现数据库连接池
实例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
java weblogic
服务器对请求的鉴权可以在请求头中加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
java spring local global transaction
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
linux alias
用途说明
设置命令的别名。在linux系统中如果命令太长又不符合用户的习惯,那么我们可以为它指定一个别名。虽然可以为命令建立“链接”解决长文件名的问 题,但对于带命令行参数的命令,链接就无能为力了。而指定别名则可以解决此类所有问题【1】。常用别名来简化ssh登录【见示例三】,使长命令变短,使常 用的长命令行变短,强制执行命令时询问等。
常用参数
格式:alias
格式:ali
yii2 restful web服务[格式响应]
dcj3sjt126com
PHP yii2
响应格式
当处理一个 RESTful API 请求时, 一个应用程序通常需要如下步骤 来处理响应格式:
确定可能影响响应格式的各种因素, 例如媒介类型, 语言, 版本, 等等。 这个过程也被称为 content negotiation。
资源对象转换为数组, 如在 Resources 部分中所描述的。 通过 [[yii\rest\Serializer]]
MongoDB索引调优(2)——[十]
eksliang
mongodb MongoDB索引优化
转载请出自出处: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
JavaScript jquery Web html5 css
体验效果: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 7 windows 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.
DAO POJO DTO po VO 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/