Naive Operations
Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 502768/502768 K (Java/Others) Total Submission(s): 853 Accepted Submission(s): 318
Problem Description
In a galaxy far, far away, there are two integer sequence a and b of length n. b is a static permutation of 1 to n. Initially a is filled with zeroes. There are two kind of operations: 1. add l r: add one for al,al+1...ar 2. query l r: query ∑ri=l⌊ai/bi⌋
Input
There are multiple test cases, please read till the end of input file. For each test case, in the first line, two integers n,q, representing the length of a,b and the number of queries. In the second line, n integers separated by spaces, representing permutation b. In the following q lines, each line is either in the form 'add l r' or 'query l r', representing an operation. 1≤n,q≤100000, 1≤l≤r≤n, there're no more than 5 test cases.
Output
Output the answer for each 'query', each one line.
Sample Input
5 12 1 5 2 4 3 add 1 4 query 1 4 add 2 5 query 2 5 add 3 5 query 1 5 add 2 4 query 1 4 add 2 5 query 2 5 add 2 2 query 1 5
Sample Output
1 1 2 4 4 6
Source
2018 Multi-University Training Contest 2
Recommend
chendu | We have carefully selected several similar problems for you: 6318 6317 6316 6315 6314
Statistic | Submit | Discuss | Note
思路:
维护一个区间 a 的最大值,b的最小值,用一个lazy来标记区间增加过的次数,当maxa
具体细节 当更新到单点并且 maxa >= minb 时,区间答案加一,minb+=b[l]
其他基本是线段树板子。
代码如下:
#include
using namespace std;
const int maxn=1e5+10;
struct node{
int l,r,fg,miv,mav,s;
}tr[maxn<<2];
int n,m,b[maxn],l,r;
char s[20];
void pushup(int i){
tr[i].miv=min(tr[i<<1].miv,tr[i<<1|1].miv);
tr[i].s=tr[i<<1].s+tr[i<<1|1].s;
tr[i].mav=max(tr[i<<1].mav,tr[i<<1|1].mav);
}
void pushdown(int i){
if(tr[i].fg){
tr[i<<1].fg+=tr[i].fg;
tr[i<<1|1].fg+=tr[i].fg;
tr[i<<1].mav+=tr[i].fg;
tr[i<<1|1].mav+=tr[i].fg;
tr[i].fg=0;
}
}
void build(int l,int r,int i){
tr[i].l=l,tr[i].r=r;
tr[i].fg=0;
if(l==r){
tr[i].miv=b[l];
tr[i].s=tr[i].mav=0;
return;
}
int mid=l+r>>1;
build(l,mid,i<<1);
build(mid+1,r,i<<1|1);
pushup(i);
}
void update(int l,int r,int i){
// printf("update %d %d %d %d %d\n",l,r,tr[i].l,tr[i].r,i);
if(l<=tr[i].l && tr[i].r<=r){
tr[i].mav++;
if(tr[i].mav=tr[i].miv){
tr[i].s++;
tr[i].miv+=b[tr[i].l];
return ;
}
}
pushdown(i);
int mid=tr[i].l+tr[i].r>>1;
if(l<=mid) update(l,r,i<<1);
if(r>mid) update(l,r,i<<1|1);
pushup(i);
}
int Query(int l,int r,int i){
if(l<=tr[i].l && tr[i].r<=r) return tr[i].s;
pushdown(i);
int ans=0,mid=tr[i].l+tr[i].r>>1;
if(l<=mid) ans+=Query(l,r,i<<1);
if(r>mid) ans+=Query(l,r,i<<1|1);
return ans;
}
int main(){
while(scanf("%d%d",&n,&m)==2){
for (int i=1; i<=n ;i++) scanf("%d",&b[i]);
build(1,n,1);
while(m--){
scanf("%s%d%d",s,&l,&r);
if(s[0]=='a') update(l,r,1);
else printf("%d\n",Query(l,r,1));
}
}
return 0;
}
你可能感兴趣的:(线段树)
蓝桥杯刷题 Day5 线段树(树状数组)
雁于飞
蓝桥杯 职场和发展 学习 笔记 数据结构 算法 java
蓝桥杯刷题Day5线段树文章目录蓝桥杯刷题Day5线段树前言完整代码一、树状数组1.解题思路1.1问题抽象1.2核心思想1.2适用条件:1.3典型应用:2.拆解代码2.1主函数2.1.1输入以及初始化2.1.2处理查询2.2SegmentTree类2.2.1初始化数组以及最低有效位2.2.2单点更新与集区间求和二、题后收获3.1知识点前言今天写牛客网模板题中数据结构的线段树完整代码一、树状数组原题
P3740 [HAOI2014] 贴海报 题解
lhschris
题解
P3740[HAOI2014]贴海报题解思路我们模拟一下贴海报的过程,先把x∼yx\simyx∼y的数字全部变成kkk。后面的数字可以覆盖前面的数字。如果for循环枚举的话是会超时的,我们考虑用线段树维护区间数字。那么所有操作结束后如果当前区间还有当前数字,ans++ans++ans++。那么这么判断呢?也就是pushup怎么做?求最小值最好了。因为每个区间的最小值只能是当前数字,因为当前区间已经
小木的算法日记-线段树
木旭林晖
算法
线段树(SegmentTree):玩转区间作的终极利器你好,未来的算法大师!想象一下,你正在处理一个巨大的数据集,比如某个电商网站一整天的用户点击流。老板突然问你:“下午2点到3点之间,我们的总点击量是多少?”几分钟后,他又问:“把10点到11点之间的数据,因为系统故障,全部乘以0.5,然后再告诉我下午的总点击量。”如果用普通的数组,每次查询都需要遍历,每次修改更是灾难。面对这种需求,我们该怎么办
【贪心、DP、线段树优化】Leetcode 376. 摆动序列
Wendy_robot
leetcode 算法
贪心算法:选“关键转折点”初始状态:把数组第一个元素当作起点,此时前一个差值符号设为平坡(即差值为0)。遍历数组:从第二个元素开始,依次计算当前元素和前一个元素的差值。差值符号判断:差值大于0:要是之前的差值是小于等于0(平坡或者下降状态),那就说明找到了一个从下降到上升的摆动点,更新最大摆动点数,同时把前一个差值符号标记为上升(大于0)。差值小于0:若之前的差值是大于等于0(平坡或者上升状态),
Codeforces Round 974 (Div. 3) A-F
swan416
题解 图论 算法 c++ 数据结构 算法竞赛 Codeforces 信息学竞赛
封面原图画师礼島れいあ下午的ICPC网络赛的难受一晚上全都给我打没了手速拉满再加上秒杀线段树这场简直了啊唯一可惜的是最后还是掉出了1000名一把上蓝应该没啥希望了吧A-RobinHelps题意侠盗罗宾因劫富济贫而闻名于世罗宾遇到的nnn人,从1st1_{st}1st开始,到nthn_{th}nth结束。iii第三个人有aia_iai金子。如果是ai≥ka_i\gekai≥k,罗宾会拿走所有的aia
【Algorithm】Segment Tree 简单介绍
CodeWithMe
C/C++ c++ 算法 python
文章目录SegmentTree1基本概念2基本思想3适用场景4代码示例(区间求和)5使用示例6使用注意事项7进阶拓展SegmentTree线段树(SegmentTree)是一种高级数据结构,主要用于在区间范围内高效地进行查询与修改操作。它是一个二叉树结构,每个节点代表一个区间的信息,通常用于解决如下问题:1基本概念线段树是对一个区间[l,r]上的数列进行划分,并在每个子区间上维护某种信息(如最值、
【算法笔记】树套树
PXM的算法星球
算法笔记 算法 笔记
一、前言在面对二维区间统计问题时,比如:查询某个一维区间中,大于某个值的数的个数对一个序列同时支持区间查询+单点修改我们常用的一维数据结构(如线段树、树状数组)往往显得力不从心。此时,我们可以考虑一种高效的数据结构组合:树套树。二、什么是树套树?“树套树”顾名思义,就是一棵树中的每个节点再套一棵树。最常见的树套树结构是:外层:线段树/树状数组,按照下标维护区间内层:平衡树(如STLmultiset
Python·算法分类题库
欢迎关注【Python·算法分类题库】,持续更新中……知识点A字符串(AC自动机、拓展KMP、后缀数组、后缀自动机、回文自动机)图论(网络流、一般图匹配)数学(生成函数、莫比乌斯反演、快速傅里叶变换)数据结构(树链剖分、二维/动态开点线段树、平衡树、可持久化数据结构、树套树、动态树)B排序(归并、快速、桶、堆、基数)搜索(剪枝、双向BFS、记忆化搜索、迭代加深搜索、启发式搜索)DP(背包、树形、状
蓝桥杯康复训练 Day4 (前缀和)(树状数组)(线段树)
ooold_six
2022蓝桥杯 java 算法
昨天没状态摆了一天,今天复习一下各种区间问题前缀和常规遍历区间求和复杂度O(n)单点修改复杂度O(1)前缀和区间求和复杂度O(1)单点修改复杂度O(n)前缀和数组中每个值覆盖的是从开始到该点整个区间的和值求i~j的区间和值可以通过s[j]-s[i-1]计算可以扩展成二维三维的前缀和在单点修改时需要对所有覆盖该点的值进行修改在对区间求和复杂度要求高时使用蓝桥杯–前缀和1树状数组对比前缀和复杂度前缀和
线段树刷题1
code自留地
线段树
[TJOI2009]开关luogu链接:https://www.luogu.com.cn/problem/P3870ps:好好的一道省选题打绿了不说,居然是道橙题!也就和一道dfs的难度一样···你洛谷是不是人均线段树??分析题意:我们仍然是要进行区间修改的操作,那懒标记是逃不过了喂·然后我们分析至少需要维护哪些信息:亮灯总个数是需要维护的吧但是这样够不够?因为我们还要表示出“亮灯变暗,暗灯点亮”
线段树刷题记录
弥彦_
c++ 算法 c++ 数据结构
一、区间查询无修改:(一)最值问题:1.P1816忠诚-洛谷思路:模板。注意:无。代码:#include#defineiosccios::sync_with_stdio(false),cin.tie(0),cout.tie(0)#defineendl'\n'#defineme(a,x)memset(a,x,sizeofa)#defineall(a)a.begin(),a.end()#defines
数据结构---线段树
4FGR
数据结构 开发语言 c++ 算法 数据结构
线段树参考:线段树-OIWiki线段树是一种二叉搜索树、平衡二叉树,对于区间的修改、维护和查询时间复杂度优化为log级别。对区间不断做平分区间,直到划分到只有一个或多个数据的区间,可表示区间的和或者最小最大值。在进行更新区间操作时,通过小区间更新大区间。对于下面的内容,我们主要针对于区间加法的线段树(即其节点表示区间之和)。局限性:问题需满足区间加法:对于[L,R]的区间,它的答案可以由[L,M]
洛谷所有 NOI/NOI+/CTSC 的题目
一个不会写代码的小白
c++ 洛谷 洛谷 NOI/NOI+/CTSC c++ 算法 数据结构 开发语言
洛谷——luoguOJ所有NOI/NOI+/CTSC的P/C开头题目P8861线段P5111zhtobu3232的线段树P7719「EZEC-10」多彩的线段P5210[ZJOI2017]线段树P10145[WC2024]线段树P10211[CTS2024]线段树P7445「EZEC-7」线段树P5342[TJOI2019]甲苯先生的线段树P8498[NOI2022]树上邻域数点P5659[CSP
USST新生训练赛3KLMN
Fighter_sky
题解 C++ acm
题解前言题解部分KPashmakandParmida'sproblem(1800)题目大意题解参考代码LPashmakandGraph(1900)题目大意题解参考代码MLuckyChains(1600)题目大意题解参考代码NManipulatingHistory(1600)题目大意题解参考代码前言KLMN是数据结构(线段树/树状数组)+dp+数论+结论唐题题解部分KPashmakandParmid
权值线段树和可持久化线段树(主席树)
.Q_W.
算法 算法 数据结构
目录权值线段树权值线段树的基本概念权值线段树的构建权值线段树的操作添加元素查询区间[l,r]的元素个数查询整个集合中第k小(或第k大)的元素值例题代码实现可持久化线段树(主席树)例题1代码实现例题2思路代码实现权值线段树权值线段树的基本概念权值线段树是一种特殊的线段树,它的叶子节点存储的是某个元素的权值(通常是该元素的出现次数),而不是元素本身。分支节点则存储其子节点权值的某种集合值(如和、最值等
关于队里面最菜的在博客打卡第三十七天这件事
算法好难 TAT
算法 数据结构 线段树 mex
传送门:很难想象一个非要暴力去解题人的精神状态这是一道神奇的题,题意是给你一个序列,然后问你这个序列是否可以用两个排列拼接而成,并且一左一右,如果可以的话有几种情况。问题十分的棘手(后来才发现只有3种结果),刚开始想用线段树或者树状数组去维护左右区间的数的个数,再判断数的多少和区间的大小,后来发现重复数据会出现很多问题,而且并且没有想到办法解决,于是突发奇想,好像区间的mex和区间的大小可以用来判
高级数据结构 - 线段树、权值线段树(Java & JS & Python)
程序员阿甘
算法 数据结构 Java JavaScript Python
引子现在给定一个数组arr=[4,7,5,3,8,9,0,1,2,6],arr.length=n,无规律地多次进行如下操作:查询arr指定区间[l,r]内最大值max查询arr指定区间[l,r]内元素之和sumarr指定索引i位置的元素新增C或者覆盖为Carr指定区间[l,r]内每个元素值新增C或者覆盖为C其中:查询(区间最大值、区间和)的时间复杂度为O(n)单值更新的时间复杂度为O(1)区间更新
高级数据结构之线段树(Segment Tree)
白马负金羁
数据结构与算法分析 线段树 Segment Tree LeetCode307 数据结构
线段树(SegmentTree)也是一种树形的数据结构(本质上是一棵二叉搜索树),只不过树中结点存储的值是一个区间或一个线段。常用于区间内数值的查询操作,比如一个区间内的最大值(max),最小值(min),以及加和(sum)等等。该结构由美国计算机科学家JonBentley于1977年提出,JonBentley还是畅销书《编程珠玑》的作者。有些资料上将线段树和区间树(IntervalTrees)混
[LeetCode] 树状数组+线段树总结
virgilshi
树状数组 线段树 LeetCode
文章目录写在前面线段树树桩数组相关题写在前面LeetCode树状数组+线段树的题比较少,而且这两个知识点在面试时被考察的概率极小,但是如果我们知道这两个知识点,在解题的时候会非常便捷(利用高维度工具打击低维度题目,解题所需的思维量会少很多),本文也是出于学习树状数组和线段树的目的写在这篇博客的。线段树线段树是二叉树形态的数据结构,用于存储和查询包含某个点的所有区间,时间复杂度为O(lgn+k),k
树状数组与线段树入门
Maximum_Mighty_X
c++
树状数组和线段树都是用于处理动态区间问题的数据结构。树状数组:支持区间加法的同时区间查询区间和,以及最值;线段树:支持区间加法的同时区间乘法的同时区间查询区间和,以及最值。线段树的适用范围相较于树状数组更加广泛,但树状数组相对于线段树简洁很多,且常数极小。树状数组树状数组的空间复杂度为O(n),时间上单次查询为O(logn)。首先我们需要知道这个定义:lowbit(x):表示x在二进制下从低位往高
kuangbin 最小生成树专题 - POJ - 2421 Constructing Roads (朴素 Prim算法 模板题)
会划水才能到达彼岸
最小生成树专题 kuangbin 题单 算法 图论 c++ 数据结构 树结构
kuangbin最小生成树专题-POJ-2421ConstructingRoads(朴素Prim算法模板题)英文版Clickhere~~意译版Clickhere~~总题单week3[kuangbin带你飞]题单最小生成树+线段树Clickhere~~https://blog.csdn.net/m0_46272108/article/details/108980362英文版Clickhere~~De
【刷题2025】贪心算法+KMP算法+暴力枚举+扫描树线段树+LFU缓存
cIlIegia_1234
算法 贪心算法
1.贪心算法(1)火锅题目描述入职后,导师会请你吃饭,你选择了火锅。火锅里会在不同时间下很多菜.不同食材要煮不同的时间,才能变得刚好合适。你希望吃到最多的刚好合适的菜,但你的手速不够快,用m代表手速,每次下手捞菜后至少要过m秒才能再捞(每次只能捞一个)。那么用最合理的策略,最多能吃到多少刚好合适的菜?输入描述第一行两个整数n,m,其中n代表往锅里下的菜的个数,m代表手速。(1=m:ans+=1pr
Python蓝桥杯算法模板
敲击大怪兽
python 蓝桥杯 算法
Python蓝桥杯算法模板今天来给大家分享超实用的Python蓝桥杯算法模板,助力大家在蓝桥杯比赛中披荆斩棘~目录sys库math库datetime库queue库list常用apiset常用apistr常用api进制转换与排序并查集(DSU)最短路径(Dijkstra)线段树(SegTree)sys库sys库是Python的标准库,它提供了许多与Python解释器和系统环境相关的功能。比如sys.
关于python与c++效率的对比实战
鸿雁拉着我飞
python 效率 C++ 排序
c语言是编译型语言,python是解释型语言,因此两者的效率有不小的差距,可没想到差距那么大。最近跟hackerrank上一道排序的题目杠上了(感兴趣的同学可以去看看,名为sortedsubsegment),用的python,废了几天功夫都没解出来。终于还是看了答案(用的是二分查找的思想与线段树的数据结构),答案是java写的。于是我用python实现出来,速度依然不行。于是又用c++写了一遍。结
蓝桥杯python组备赛(记录个人模板)
潇湘夜雨697
算法专项 蓝桥杯 python
文章目录栈队列堆递归装饰器并查集树状数组线段树最近公共祖先LCAST表字典树KMPmanacher跳表(代替C++STL的set)dijkstra总结栈用list代替队列用deque双端队列替代堆用heapq递归装饰器众所周知,python的递归深度只有1000,根本满足不了大部分1e5以上的数据,当然你可以使用sys.setrecursionlimit(1000000)扩到1e6,但是这会增加空
算法整理 & 复习
SP FA
数据结构与算法 c++ 算法 数据结构
搬自hzwer文章目录一、基本数据结构1.数组2.链表、双向链表3.队列、单调队列、双端队列4.栈、单调栈5.前缀和、差分二、中级数据结构1.堆2.并查集、带权并查集3.哈希、哈希冲突三、高级数据结构1.树状数组2.线段树、线段树合并3.平衡树3.1Treap随机平衡二叉树3.2Splay伸展树3.3替罪羊树3.4红黑树4.块状数组、块状链表5.树套树5.1线段树套线段树5.2线段树套平衡树5.3
玩转数据结构 java描述 一 概况
Qqun954715313
互联网 java 程序员 数据结构
第一章介绍,数据结构是计算机专业的同学必学的课程数据结构研究的是数据如何在计算机进行组织和存储,使得我们可以高效的获取数据或者修改数据。数据结构可以分为三种结构:线性结构:数组;栈;队列;链表;哈希表树结构:二叉树,二分搜索树,AVL,红黑树,Treap,Splay,堆,Trie,线段树,K-D树,并查集,哈夫曼树图结构邻接矩阵,邻接表我们需要根据应用的不同,灵活选择最合适的数据结构,例子:1,数
树状数组、线段树 | P8613 [蓝桥杯 2014 省 B] 小朋友排队C++题解
一只一只
蓝桥杯 c++ 算法
P8613[蓝桥杯2014省B]小朋友排队原题链接题目描述nnn个小朋友站成一排。现在要把他们按身高从低到高的顺序排列,但是每次只能交换位置相邻的两个小朋友。每个小朋友都有一个不高兴的程度。开始的时候,所有小朋友的不高兴程度都是000。如果某个小朋友第一次被要求交换,则他的不高兴程度增加111,如果第二次要求他交换,则他的不高兴程度增加222(即不高兴程度为333),依次类推。当要求某个小朋友第k
线段树_P3372/P3373_Python
How_doyou_do
数据结构 python 算法 线段树
前面是线段树的模版代码,后面有例题P3372和P3373的应用话不多说,上代码classNode:#节点类def__init__(self,l,r):self.l=l#区间左端点self.r=r#区间右端点self.left=None#左子节点self.right=None#右子节点self.sum=0#区间和self.max=-float('inf')#区间最大值self.min=float('
扫描线&离散化&线段树解决矩形面积并-洛谷P5490
什码情况
算法 数据结构 C++ 线段树 扫描线
https://www.luogu.com.cn/problem/P5490题目描述求nnn个四边平行于坐标轴的矩形的面积并。输入格式第一行一个正整数nnn。接下来nnn行每行四个非负整数x1,y1,x2,y2x_1,y_1,x_2,y_2x1,y1,x2,y2,表示一个矩形的四个端点坐标为(x1,y1),(x1,y2),(x2,y2),(x2,y1)(x_1,y_1),(x_1,y_2),(x_
jvm调优总结(从基本概念 到 深度优化)
oloz
java jvm jdk 虚拟机 应用服务器
JVM参数详解:http://www.cnblogs.com/redcreen/archive/2011/05/04/2037057.html
Java虚拟机中,数据类型可以分为两类:基本类型和引用类型。基本类型的变量保存原始值,即:他代表的值就是数值本身;而引用类型的变量保存引用值。“引用值”代表了某个对象的引用,而不是对象本身,对象本身存放在这个引用值所表示的地址的位置。
【Scala十六】Scala核心十:柯里化函数
bit1129
scala
本篇文章重点说明什么是函数柯里化,这个语法现象的背后动机是什么,有什么样的应用场景,以及与部分应用函数(Partial Applied Function)之间的联系 1. 什么是柯里化函数
A way to write functions with multiple parameter lists. For instance
def f(x: Int)(y: Int) is a
HashMap
dalan_123
java
HashMap在java中对很多人来说都是熟的;基于hash表的map接口的非同步实现。允许使用null和null键;同时不能保证元素的顺序;也就是从来都不保证其中的元素的顺序恒久不变。
1、数据结构
在java中,最基本的数据结构无外乎:数组 和 引用(指针),所有的数据结构都可以用这两个来构造,HashMap也不例外,归根到底HashMap就是一个链表散列的数据
Java Swing如何实时刷新JTextArea,以显示刚才加append的内容
周凡杨
java 更新 swing JTextArea
在代码中执行完textArea.append("message")后,如果你想让这个更新立刻显示在界面上而不是等swing的主线程返回后刷新,我们一般会在该语句后调用textArea.invalidate()和textArea.repaint()。
问题是这个方法并不能有任何效果,textArea的内容没有任何变化,这或许是swing的一个bug,有一个笨拙的办法可以实现
servlet或struts的Action处理ajax请求
g21121
servlet
其实处理ajax的请求非常简单,直接看代码就行了:
//如果用的是struts
//HttpServletResponse response = ServletActionContext.getResponse();
// 设置输出为文字流
response.setContentType("text/plain");
// 设置字符集
res
FineReport的公式编辑框的语法简介
老A不折腾
finereport 公式 总结
FINEREPORT用到公式的地方非常多,单元格(以=开头的便被解析为公式),条件显示,数据字典,报表填报属性值定义,图表标题,轴定义,页眉页脚,甚至单元格的其他属性中的鼠标悬浮提示内容都可以写公式。
简单的说下自己感觉的公式要注意的几个地方:
1.if语句语法刚接触感觉比较奇怪,if(条件式子,值1,值2),if可以嵌套,if(条件式子1,值1,if(条件式子2,值2,值3)
linux mysql 数据库乱码的解决办法
墙头上一根草
linux mysql 数据库乱码
linux 上mysql数据库区分大小写的配置
lower_case_table_names=1 1-不区分大小写 0-区分大小写
修改/etc/my.cnf 具体的修改内容如下:
[client]
default-character-set=utf8
[mysqld]
datadir=/var/lib/mysql
socket=/va
我的spring学习笔记6-ApplicationContext实例化的参数兼容思想
aijuans
Spring 3
ApplicationContext能读取多个Bean定义文件,方法是:
ApplicationContext appContext = new ClassPathXmlApplicationContext(
new String[]{“bean-config1.xml”,“bean-config2.xml”,“bean-config3.xml”,“bean-config4.xml
mysql 基准测试之sysbench
annan211
基准测试 mysql基准测试 MySQL测试 sysbench
1 执行如下命令,安装sysbench-0.5:
tar xzvf sysbench-0.5.tar.gz
cd sysbench-0.5
chmod +x autogen.sh
./autogen.sh
./configure --with-mysql --with-mysql-includes=/usr/local/mysql
sql的复杂查询使用案列与技巧
百合不是茶
oracle sql 函数 数据分页 合并查询
本片博客使用的数据库表是oracle中的scott用户表;
------------------- 自然连接查询
查询 smith 的上司(两种方法)
&
深入学习Thread类
bijian1013
java thread 多线程 java多线程
一. 线程的名字
下面来看一下Thread类的name属性,它的类型是String。它其实就是线程的名字。在Thread类中,有String getName()和void setName(String)两个方法用来设置和获取这个属性的值。
同时,Thr
JSON串转换成Map以及如何转换到对应的数据类型
bijian1013
java fastjson net.sf.json
在实际开发中,难免会碰到JSON串转换成Map的情况,下面来看看这方面的实例。另外,由于fastjson只支持JDK1.5及以上版本,因此在JDK1.4的项目中可以采用net.sf.json来处理。
一.fastjson实例
JsonUtil.java
package com.study;
impor
【RPC框架HttpInvoker一】HttpInvoker:Spring自带RPC框架
bit1129
spring
HttpInvoker是Spring原生的RPC调用框架,HttpInvoker同Burlap和Hessian一样,提供了一致的服务Exporter以及客户端的服务代理工厂Bean,这篇文章主要是复制粘贴了Hessian与Spring集成一文,【RPC框架Hessian四】Hessian与Spring集成
在
【RPC框架Hessian二】Hessian 对象序列化和反序列化一文中
【Mahout二】基于Mahout CBayes算法的20newsgroup的脚本分析
bit1129
Mahout
#!/bin/bash
#
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information re
nginx三种获取用户真实ip的方法
ronin47
随着nginx的迅速崛起,越来越多公司将apache更换成nginx. 同时也越来越多人使用nginx作为负载均衡, 并且代理前面可能还加上了CDN加速,但是随之也遇到一个问题:nginx如何获取用户的真实IP地址,如果后端是apache,请跳转到<apache获取用户真实IP地址>,如果是后端真实服务器是nginx,那么继续往下看。
实例环境: 用户IP 120.22.11.11
java-判断二叉树是不是平衡
bylijinnan
java
参考了
http://zhedahht.blog.163.com/blog/static/25411174201142733927831/
但是用java来实现有一个问题。
由于Java无法像C那样“传递参数的地址,函数返回时能得到参数的值”,唯有新建一个辅助类:AuxClass
import ljn.help.*;
public class BalancedBTree {
BeanUtils.copyProperties VS PropertyUtils.copyProperties
诸葛不亮
PropertyUtils BeanUtils
BeanUtils.copyProperties VS PropertyUtils.copyProperties
作为两个bean属性copy的工具类,他们被广泛使用,同时也很容易误用,给人造成困然;比如:昨天发现同事在使用BeanUtils.copyProperties copy有integer类型属性的bean时,没有考虑到会将null转换为0,而后面的业
[金融与信息安全]最简单的数据结构最安全
comsci
数据结构
现在最流行的数据库的数据存储文件都具有复杂的文件头格式,用操作系统的记事本软件是无法正常浏览的,这样的情况会有什么问题呢?
从信息安全的角度来看,如果我们数据库系统仅仅把这种格式的数据文件做异地备份,如果相同版本的所有数据库管理系统都同时被攻击,那么
vi区段删除
Cwind
linux vi 区段删除
区段删除是编辑和分析一些冗长的配置文件或日志文件时比较常用的操作。简记下vi区段删除要点备忘。
vi概述
引文中并未将末行模式单独列为一种模式。单不单列并不重要,能区分命令模式与末行模式即可。
vi区段删除步骤:
1. 在末行模式下使用:set nu显示行号
非必须,随光标移动vi右下角也会显示行号,能够正确找到并记录删除开始行
清除tomcat缓存的方法总结
dashuaifu
tomcat 缓存
用tomcat容器,大家可能会发现这样的问题,修改jsp文件后,但用IE打开 依然是以前的Jsp的页面。
出现这种现象的原因主要是tomcat缓存的原因。
解决办法如下:
在jsp文件头加上
<meta http-equiv="Expires" content="0"> <meta http-equiv="kiben&qu
不要盲目的在项目中使用LESS CSS
dcj3sjt126com
Web less
如果你还不知道LESS CSS是什么东西,可以看一下这篇文章,是我一朋友写给新人看的《CSS——LESS》
不可否认,LESS CSS是个强大的工具,它弥补了css没有变量、无法运算等一些“先天缺陷”,但它似乎给我一种错觉,就是为了功能而实现功能。
比如它的引用功能
?
.rounded_corners{
[入门]更上一层楼
dcj3sjt126com
PHP yii2
更上一层楼
通篇阅读完整个“入门”部分,你就完成了一个完整 Yii 应用的创建。在此过程中你学到了如何实现一些常用功能,例如通过 HTML 表单从用户那获取数据,从数据库中获取数据并以分页形式显示。你还学到了如何通过 Gii 去自动生成代码。使用 Gii 生成代码把 Web 开发中多数繁杂的过程转化为仅仅填写几个表单就行。
本章将介绍一些有助于更好使用 Yii 的资源:
Apache HttpClient使用详解
eksliang
httpclient http协议
Http协议的重要性相信不用我多说了,HttpClient相比传统JDK自带的URLConnection,增加了易用性和灵活性(具体区别,日后我们再讨论),它不仅是客户端发送Http请求变得容易,而且也方便了开发人员测试接口(基于Http协议的),即提高了开发的效率,也方便提高代码的健壮性。因此熟练掌握HttpClient是很重要的必修内容,掌握HttpClient后,相信对于Http协议的了解会
zxing二维码扫描功能
gundumw100
android zxing
经常要用到二维码扫描功能
现给出示例代码
import com.google.zxing.WriterException;
import com.zxing.activity.CaptureActivity;
import com.zxing.encoding.EncodingHandler;
import android.app.Activity;
import an
纯HTML+CSS带说明的黄色导航菜单
ini
html Web html5 css hovertree
HoverTree带说明的CSS菜单:纯HTML+CSS结构链接带说明的黄色导航
在线体验效果:http://hovertree.com/texiao/css/1.htm代码如下,保存到HTML文件可以看到效果:
<!DOCTYPE html >
<html >
<head>
<title>HoverTree
fastjson初始化对性能的影响
kane_xie
fastjson 序列化
之前在项目中序列化是用thrift,性能一般,而且需要用编译器生成新的类,在序列化和反序列化的时候感觉很繁琐,因此想转到json阵营。对比了jackson,gson等框架之后,决定用fastjson,为什么呢,因为看名字感觉很快。。。
网上的说法:
fastjson 是一个性能很好的 Java 语言实现的 JSON 解析器和生成器,来自阿里巴巴的工程师开发。
基于Mybatis封装的增删改查实现通用自动化sql
mengqingyu
DAO
1.基于map或javaBean的增删改查可实现不写dao接口和实现类以及xml,有效的提高开发速度。
2.支持自定义注解包括主键生成、列重复验证、列名、表名等
3.支持批量插入、批量更新、批量删除
<bean id="dynamicSqlSessionTemplate" class="com.mqy.mybatis.support.Dynamic
js控制input输入框的方法封装(数字,中文,字母,浮点数等)
qifeifei
javascript js
在项目开发的时候,经常有一些输入框,控制输入的格式,而不是等输入好了再去检查格式,格式错了就报错,体验不好。 /** 数字,中文,字母,浮点数(+/-/.) 类型输入限制,只要在input标签上加上 jInput="number,chinese,alphabet,floating" 备注:floating属性只能单独用*/
funct
java 计时器应用
tangqi609567707
java timer
mport java.util.TimerTask; import java.util.Calendar; public class MyTask extends TimerTask { private static final int
erlang输出调用栈信息
wudixiaotie
erlang
在erlang otp的开发中,如果调用第三方的应用,会有有些错误会不打印栈信息,因为有可能第三方应用会catch然后输出自己的错误信息,所以对排查bug有很大的阻碍,这样就要求我们自己打印调用的栈信息。用这个函数:erlang:process_display (self (), backtrace).需要注意这个函数只会输出到标准错误输出。
也可以用这个函数:erlang:get_s