- SJTU火车调度(OJ1049)
cjx11235
数据结构sjtu栈数据结构c++
题目源自SJTUOJ1049有一条东西方向的铁路穿过小城A,小城A有一个火车调度站,示意图如下:火车调度现在有N列火车自东向西依次开过来了,按照到达的先后次序编号为0号到N-1号。根据调度局的要求,小城A的调度站要改变这些列车驶离A城的顺序。为了达到这一目的,调度站在任意时刻可以执行以下三种操作之一:如果调度站还有剩余空间,则可以令下一列开来的火车进入调度站;如果调度站内有列车,则可以令调度站最前
- SJTUOJ1002. 二哥种花生(二维前缀和)
学着长大.
前缀和与差分
Description二哥在自己的后花园里种了一些花生,也快到了收获的时候了。这片花生地是一个长度为L、宽度为W的矩形,每个单位面积上花生产量都是独立的。他想知道,对于某个指定的区域大小,在这么大的矩形区域内,花生的产量最大会是多少。InputFormat第1行有2个整数,长度L和宽度W。第2行至第L+1行,每行有W个整数,分别表示对应的单位面积上的花生产量A(0≤A#include#includ
- SJTU OJ 1990 二哥听CD
BorisChen1998
SJTUOJ
SJTUOJ1990二哥听CD原题链接这道题用暴力解法也可以过,因为好感度每次都只加减1,一般不会有太多的移动。但是不经过好的优化,还是会超时的。记录好每个CD移动之后的位置就可以了。#include#includeusingnamespacestd;structcd{intindex;intweight;};intn,m;cdarr[2000005];intmovenode[2000005]={
- SJTU OJ 1228 Matrix Sum
BorisChen1998
SJTUOJ
SJTUOJ1228MatrixSum原题链接这道题做法不唯一,这里只写一个我第一次做时想出来的一个方法。首先令所有奇数为1,所有偶数为0。假定一个单行的矩阵,比如是00101100011101,数其中和为奇数的子矩阵个数。我们发现连续的0取其中不论几个都不影响奇偶。假设有n个连续的0,那么可以取0~n一共n+1种情况。当矩阵只含有第一个1时,两侧的0的取法有3*2=6种。当矩阵含有前三个1时,有
- SJTU OJ 3008 Maze
BorisChen1998
SJTUOJSJTUOJC++算法题
SJTUOJ3008Maze原题链接第一次写关于bfs遍历图的题目,整理一下。用队列存储可行的结点,pass[][]存储是否走过。我的代码如下:#include#include#includeusingnamespacestd;intn,m,x1,y1,x2,y2;chararr[105][105];boolpass[105][105]={false};intxx[4]={1,0,0,-1};//
- SJTU OJ 1558 最长序列问题
BorisChen1998
SJTUOJ
SJTUOJ1558最长序列问题原题链接这道题我是基本照搬ciociooo的博客的做法,只是其中的优先级队列我改用了自己写的版本。同时又添加了一些注释方便我看懂。下面是代码:#include#include#includeusingnamespacestd;intmmax(intx,inty){returnx>y?x:y;}structmypair{intfirst;intsecond;mypai
- SJTU OJ 1056 二哥吃糖
BorisChen1998
SJTUOJ
SJTUOJ1056二哥吃糖原题链接这道题查找第q大的糖果数用平衡树就可以(平衡度用结点个数而不是高度,返回第q大更快)。其他要注意的就是标记好几号盒子并到了几号盒子里。初始化第i个糖果在第i个盒子里。下面是代码:#include#includeusingnamespacestd;intm,n;intbox[500005];//每个盒子多少个糖;intsugar[500005];//每个糖属于几号
- SJTU OJ 1069 二哥的硬币
BorisChen1998
SJTUOJ
SJTUOJ1069二哥的硬币原题链接此题很久之前所写,觉得对于背包问题很有代表意义,就整理一下。每个面值x的硬币看做价值w=x,占空间v=x的一个物品。根据同面值硬币总值是否超过m分为01背包和完全背包两类。最后判断体积i的背包是否最大能装i价值的硬币,即是否能凑成i面值。代码如下:#include#includeusingnamespacestd;intm,n;inta[105];intc[1
- SJTUOJ 1008. 二哥买期货
phoenix5443
SJTUOJ
问题内容Description二哥想知道在一段时期内,一共有多少个交易日。期货交易日的限定如下:周六、周日不能交易元旦期间(1月1日)不能交易五一劳动节期间(5月1日至3日)不能交易十一国庆节期间(10月1日至7日)不能交易没有在上述要求中提到的日期均可交易InputFormat第一行有一个整数n,表示一共有n组数据。每组数据都有一行,是两个用空格分开的日期,分别为开始日期和结束日期。日期格式为Y
- SJTUOJ 1007. 二哥领工资
phoenix5443
SJTUOJ
题目内容题目描述二哥当了多年的助教,今天终于要发工资了!二哥正在高兴之际,得知工资是分两部分发放的。第一部分是这学期的工资,另一部分是之前所有学期的工资总和。而领取工资时,出纳员会问二哥,两部分工资加在一起是多少,如果二哥回答错了,就只能领到这个学期的工资之前所有学期的劳动就白费了。二哥从小道消息得知,出纳员是个对数字敏感的人,不能有一点差错,所以二哥需要一个程序来帮他算出精确的工资总和。输入格式
- SJTUOJ 1003. 二哥养细菌
phoenix5443
SJTUOJ
题目内容题目描述二哥不仅种苹果和花生,还养了很多细菌。二哥的细菌培养皿成方格形,边长为L。长期培养后,二哥发现了细菌繁殖的规律:最初每个格子里的细菌及其后代都会独立繁殖,每次繁殖都会在其上下左右四个相邻的格子里产生新的细菌,而已经存在的细菌在培养皿充满细菌之前都不会死亡。另外,有一些格子里可能还有抗生素,细菌在有抗生素的格子里无法繁殖。二哥于是发明了一个游戏:取一个新的培养皿,在某些格子里放入细菌
- SJTUOJ 1002. 二哥种花生
phoenix5443
SJTUOJ
题目内容Description二哥在自己的后花园里种了一些花生,也快到了收获的时候了。这片花生地是一个长度为L、宽度为W的矩形,每个单位面积上花生产量都是独立的。他想知道,对于某个指定的区域大小,在这么大的矩形区域内,花生的产量最大会是多少。InputFormat第1行有2个整数,长度L和宽度W。第2行至第L+1行,每行有W个整数,分别表示对应的单位面积上的花生产量A(0≤Aints[1001][
- SJTUOJ 1001. 二哥摘苹果
phoenix5443
SJTUOJ
题目内容题目描述二哥平日喜欢自己种一些东西,并以此为写程序和看电影之外的最大爱好。最近,二哥种的一棵苹果树到了采摘的时候,但是由于二哥身高的限制,有些苹果太高摘不到。于是二哥借来了一个凳子,踩在上面可以摘到更多的苹果。二哥是一个懒于行动的人,他想在摘苹果之前知道自己能摘到多少苹果,如果实在太少(苹果树很茂盛,主要是由于身高原因),他宁可坐在树下等苹果自己掉下来砸到头上。输入格式输入共有两行。第1行
- 【SJTUOJ笔记】P1125 Typist (NOI2001 聪明的打字员)
FineArtz
算法与数据结构
https://acm.sjtu.edu.cn/OnlineJudge/problem/1125注:本文中,用←→↑↓分别表示光标左移、光标右移、加、减,swap0和swap5分别表示与第一位交换、与最后一位交换。一开始我联想到另一道有些相似的题目https://acm.sjtu.edu.cn/OnlineJudge/problem/1071,以为是动态规划。但思考之后发现那道题的动态规划想法无法
- 【SJTUOJ笔记】P1122 二哥开房间
FineArtz
算法与数据结构
https://acm.sjtu.edu.cn/OnlineJudge/problem/1122Hint已经告诉我们,这是一道线段树题。其实,此题确实展示了线段树的基本功能之一:维护01序列中区间最大连续0的长度。最普通的线段树结点中有l,r两个成员,表示该结点对应区间[l,r][l,r]。添加不同的成员可以维护不同的属性。在本题中,我们要维护01序列中最大连续0的长度,那么需要添加:lsum,表
- 【SJTUOJ笔记】P1118 Travel
FineArtz
算法与数据结构
https://acm.sjtu.edu.cn/OnlineJudge/problem/1118由于题目含有大量的合并和查询操作,很容易想到用并查集来做。关键在于,如何在合并集合的同时维护题目要求的信息。并查集的特点是,任何操作都可以变化为对集合根的操作。但反过来,却无法把根的状态改变直接反映到下面的每个集合元素中。在本题中,具体体现就是一堆旅行团会被根带着一起旅行,但无法在近似O(1)O(1)的
- 【SJTUOJ笔记】P1092 小F的地板
FineArtz
算法与数据结构
https://acm.sjtu.edu.cn/OnlineJudge/problem/1092我们先来看一看这个问题的简化版本:只用1×21×2和2×12×1两种方块覆盖m×nm×n的平面。首先,状态压缩是毋庸置疑的。若某个方块被覆盖则为1,没有被覆盖则为0。这样,每一行的状态可以用一个二进制数来表示,且其转化为十进制的大小不超过29=51229=512。为了下文扩展到当前问题,这里用递归来描述
- 【SJTUOJ笔记】P1092 小F的地板
FineArtz
算法与数据结构
https://acm.sjtu.edu.cn/OnlineJudge/problem/1092我们先来看一看这个问题的简化版本:只用1×21×2和2×12×1两种方块覆盖m×nm×n的平面。首先,状态压缩是毋庸置疑的。若某个方块被覆盖则为1,没有被覆盖则为0。这样,每一行的状态可以用一个二进制数来表示,且其转化为十进制的大小不超过29=51229=512。为了下文扩展到当前问题,这里用递归来描述
- 【SJTUOJ笔记】P1085 绿色通道
FineArtz
算法与数据结构
https://acm.sjtu.edu.cn/OnlineJudge/problem/1085读题读到一半以为是背包,读完之后发现果然没有这么简单……第一思路肯定是要dp,但由于有个t≤109t≤109在这里放着,一切时间或空间复杂度O(nt)O(nt)的类背包写法都是行不通的。再思考一番,发现check某个长度是否合理的时间复杂度是O(n2)O(n2)。这样决定了大体框架:二分答案,再用dp检
- 【SJTUOJ笔记】P1080 小F的公寓(NOIP2007 树网的核)
FineArtz
算法与数据结构
https://acm.sjtu.edu.cn/OnlineJudge/problem/1080这道题对树网的核的数据范围做了改动,增加了n=500000n=500000的数据,因此必须采用时间复杂度O(n)O(n)级别的算法。OJ上给了大段的提示,这里先原文搬过来:本题是NOIP题目,由于数据范围很小,O(N3)、O(N2)、O(N×S)等复杂度的算法都可以获得满分,但实际上存在更优秀的算法。题
- 【SJTUOJ笔记】P1080 小F的公寓(NOIP2007 树网的核)
FineArtz
算法与数据结构
https://acm.sjtu.edu.cn/OnlineJudge/problem/1080这道题对树网的核的数据范围做了改动,增加了n=500000n=500000的数据,因此必须采用时间复杂度O(n)O(n)级别的算法。OJ上给了大段的提示,这里先原文搬过来:本题是NOIP题目,由于数据范围很小,O(N3)、O(N2)、O(N×S)等复杂度的算法都可以获得满分,但实际上存在更优秀的算法。题
- 【SJTUOJ笔记】P1074 LSZ的雪地脚印
FineArtz
算法与数据结构
https://acm.sjtu.edu.cn/OnlineJudge/problem/1074雪地只有脚印和空白两种状态,可以分别用1和0代表。而查询某一块区域是否可行,就是查询这块区域内所有点的和是否为0,自然用二维前缀和比较合适。设某一块矩形左上角的坐标为(i,j)(i,j),短边长为kk,对i,j,ki,j,k进行枚举,即可得到暴力做法,时间复杂度O(n3)O(n3)。//s是前缀和数组i
- 【SJTUOJ笔记】P1072 小X的生物实验
FineArtz
算法与数据结构
https://acm.sjtu.edu.cn/OnlineJudge/problem/1072看完题目,第一感觉是:这不裸LCS吗,前面那些条件有什么用?再看数据范围,发现如果还用一般LCS的O(n2)O(n2)做法,肯定会超时。那么必须用到所给的条件:每个序列中,1..N1..N之间的每个数恰好出现5次。回想一般LCS的转移方程。用f[i,j]f[i,j]表示两个串分别到位置ii和位置jj的L
- 【SJTUOJ笔记】P1055 二哥切巧克力
FineArtz
算法与数据结构
https://acm.sjtu.edu.cn/OnlineJudge/problem/1055先明确一下重心的公式。在这道题中,从(x,y)(x,y)到(p,q)(p,q)的一块长方形巧克力的重心(xG,yG)(xG,yG)位于xG=∑pi=x(i∑qj=yρ(i,j))∑pi=x∑qj=yρ(i,j),yG=∑qj=y(j∑pi=xρ(i,j))∑pi=x∑qj=yρ(i,j).xG=∑i=x
- 【SJTUOJ笔记】P1056 二哥吃糖
FineArtz
算法与数据结构
https://acm.sjtu.edu.cn/OnlineJudge/problem/1056先看C操作。注意所有操作的参数都是糖果编号,但由于合并操作会将糖果打乱,所以我们需要设法快速找到特定编号的糖果在哪个盒子里。再加上C操作本身的合并,应该用并查集来实现这个功能。再看Q操作。Q操作询问糖果数量第p多的盒子中有多少糖果,并且指明了1>ch;switch(ch){case'C':{cin>>x
- 【SJTUOJ笔记】P1012 增长率问题
FineArtz
算法与数据结构
本题来源于SJTUOJP1012Description有一个数列,它是由自然数组成的,并且严格单调上升。最小的数不小于S,最大的不超过T。现在知道这个数列有一个性质:后一个数相对于前一个数的增长率总是百分比下的整数(如5相对于4的增长率是25%,25为整数;而9对7就不行了)。现在问:这个数列最长可以有多长?满足最长要求的数列有多少个?InputFormat输入仅有一行,包含S和T两个数。对于30
- 矩阵求逆(JAVA)初等行变换
qiuwanchi
矩阵求逆(JAVA)
package gaodai.matrix;
import gaodai.determinant.DeterminantCalculation;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
/**
* 矩阵求逆(初等行变换)
* @author 邱万迟
*
- JDK timer
antlove
javajdkschedulecodetimer
1.java.util.Timer.schedule(TimerTask task, long delay):多长时间(毫秒)后执行任务
2.java.util.Timer.schedule(TimerTask task, Date time):设定某个时间执行任务
3.java.util.Timer.schedule(TimerTask task, long delay,longperiod
- JVM调优总结 -Xms -Xmx -Xmn -Xss
coder_xpf
jvm应用服务器
堆大小设置JVM 中最大堆大小有三方面限制:相关操作系统的数据模型(32-bt还是64-bit)限制;系统的可用虚拟内存限制;系统的可用物理内存限制。32位系统下,一般限制在1.5G~2G;64为操作系统对内存无限制。我在Windows Server 2003 系统,3.5G物理内存,JDK5.0下测试,最大可设置为1478m。
典型设置:
java -Xmx
- JDBC连接数据库
Array_06
jdbc
package Util;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class JDBCUtil {
//完
- Unsupported major.minor version 51.0(jdk版本错误)
oloz
java
java.lang.UnsupportedClassVersionError: cn/support/cache/CacheType : Unsupported major.minor version 51.0 (unable to load class cn.support.cache.CacheType)
at org.apache.catalina.loader.WebappClassL
- 用多个线程处理1个List集合
362217990
多线程threadlist集合
昨天发了一个提问,启动5个线程将一个List中的内容,然后将5个线程的内容拼接起来,由于时间比较急迫,自己就写了一个Demo,希望对菜鸟有参考意义。。
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.CountDownLatch;
public c
- JSP简单访问数据库
香水浓
sqlmysqljsp
学习使用javaBean,代码很烂,仅为留个脚印
public class DBHelper {
private String driverName;
private String url;
private String user;
private String password;
private Connection connection;
privat
- Flex4中使用组件添加柱状图、饼状图等图表
AdyZhang
Flex
1.添加一个最简单的柱状图
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
<?xml version=
"1.0"&n
- Android 5.0 - ProgressBar 进度条无法展示到按钮的前面
aijuans
android
在低于SDK < 21 的版本中,ProgressBar 可以展示到按钮前面,并且为之在按钮的中间,但是切换到android 5.0后进度条ProgressBar 展示顺序变化了,按钮再前面,ProgressBar 在后面了我的xml配置文件如下:
[html]
view plain
copy
<RelativeLa
- 查询汇总的sql
baalwolf
sql
select list.listname, list.createtime,listcount from dream_list as list , (select listid,count(listid) as listcount from dream_list_user group by listid order by count(
- Linux du命令和df命令区别
BigBird2012
linux
1,两者区别
du,disk usage,是通过搜索文件来计算每个文件的大小然后累加,du能看到的文件只是一些当前存在的,没有被删除的。他计算的大小就是当前他认为存在的所有文件大小的累加和。
- AngularJS中的$apply,用还是不用?
bijian1013
JavaScriptAngularJS$apply
在AngularJS开发中,何时应该调用$scope.$apply(),何时不应该调用。下面我们透彻地解释这个问题。
但是首先,让我们把$apply转换成一种简化的形式。
scope.$apply就像一个懒惰的工人。它需要按照命
- [Zookeeper学习笔记十]Zookeeper源代码分析之ClientCnxn数据序列化和反序列化
bit1129
zookeeper
ClientCnxn是Zookeeper客户端和Zookeeper服务器端进行通信和事件通知处理的主要类,它内部包含两个类,1. SendThread 2. EventThread, SendThread负责客户端和服务器端的数据通信,也包括事件信息的传输,EventThread主要在客户端回调注册的Watchers进行通知处理
ClientCnxn构造方法
&
- 【Java命令一】jmap
bit1129
Java命令
jmap命令的用法:
[hadoop@hadoop sbin]$ jmap
Usage:
jmap [option] <pid>
(to connect to running process)
jmap [option] <executable <core>
(to connect to a
- Apache 服务器安全防护及实战
ronin47
此文转自IBM.
Apache 服务简介
Web 服务器也称为 WWW 服务器或 HTTP 服务器 (HTTP Server),它是 Internet 上最常见也是使用最频繁的服务器之一,Web 服务器能够为用户提供网页浏览、论坛访问等等服务。
由于用户在通过 Web 浏览器访问信息资源的过程中,无须再关心一些技术性的细节,而且界面非常友好,因而 Web 在 Internet 上一推出就得到
- unity 3d实例化位置出现布置?
brotherlamp
unity教程unityunity资料unity视频unity自学
问:unity 3d实例化位置出现布置?
答:实例化的同时就可以指定被实例化的物体的位置,即 position
Instantiate (original : Object, position : Vector3, rotation : Quaternion) : Object
这样你不需要再用Transform.Position了,
如果你省略了第二个参数(
- 《重构,改善现有代码的设计》第八章 Duplicate Observed Data
bylijinnan
java重构
import java.awt.Color;
import java.awt.Container;
import java.awt.FlowLayout;
import java.awt.Label;
import java.awt.TextField;
import java.awt.event.FocusAdapter;
import java.awt.event.FocusE
- struts2更改struts.xml配置目录
chiangfai
struts.xml
struts2默认是读取classes目录下的配置文件,要更改配置文件目录,比如放在WEB-INF下,路径应该写成../struts.xml(非/WEB-INF/struts.xml)
web.xml文件修改如下:
<filter>
<filter-name>struts2</filter-name>
<filter-class&g
- redis做缓存时的一点优化
chenchao051
redishadooppipeline
最近集群上有个job,其中需要短时间内频繁访问缓存,大概7亿多次。我这边的缓存是使用redis来做的,问题就来了。
首先,redis中存的是普通kv,没有考虑使用hash等解结构,那么以为着这个job需要访问7亿多次redis,导致效率低,且出现很多redi
- mysql导出数据不输出标题行
daizj
mysql数据导出去掉第一行去掉标题
当想使用数据库中的某些数据,想将其导入到文件中,而想去掉第一行的标题是可以加上-N参数
如通过下面命令导出数据:
mysql -uuserName -ppasswd -hhost -Pport -Ddatabase -e " select * from tableName" > exportResult.txt
结果为:
studentid
- phpexcel导出excel表简单入门示例
dcj3sjt126com
PHPExcelphpexcel
先下载PHPEXCEL类文件,放在class目录下面,然后新建一个index.php文件,内容如下
<?php
error_reporting(E_ALL);
ini_set('display_errors', TRUE);
ini_set('display_startup_errors', TRUE);
if (PHP_SAPI == 'cli')
die('
- 爱情格言
dcj3sjt126com
格言
1) I love you not because of who you are, but because of who I am when I am with you. 我爱你,不是因为你是一个怎样的人,而是因为我喜欢与你在一起时的感觉。 2) No man or woman is worth your tears, and the one who is, won‘t
- 转 Activity 详解——Activity文档翻译
e200702084
androidUIsqlite配置管理网络应用
activity 展现在用户面前的经常是全屏窗口,你也可以将 activity 作为浮动窗口来使用(使用设置了 windowIsFloating 的主题),或者嵌入到其他的 activity (使用 ActivityGroup )中。 当用户离开 activity 时你可以在 onPause() 进行相应的操作 。更重要的是,用户做的任何改变都应该在该点上提交 ( 经常提交到 ContentPro
- win7安装MongoDB服务
geeksun
mongodb
1. 下载MongoDB的windows版本:mongodb-win32-x86_64-2008plus-ssl-3.0.4.zip,Linux版本也在这里下载,下载地址: http://www.mongodb.org/downloads
2. 解压MongoDB在D:\server\mongodb, 在D:\server\mongodb下创建d
- Javascript魔法方法:__defineGetter__,__defineSetter__
hongtoushizi
js
转载自: http://www.blackglory.me/javascript-magic-method-definegetter-definesetter/
在javascript的类中,可以用defineGetter和defineSetter_控制成员变量的Get和Set行为
例如,在一个图书类中,我们自动为Book加上书名符号:
function Book(name){
- 错误的日期格式可能导致走nginx proxy cache时不能进行304响应
jinnianshilongnian
cache
昨天在整合某些系统的nginx配置时,出现了当使用nginx cache时无法返回304响应的情况,出问题的响应头: Content-Type:text/html; charset=gb2312 Date:Mon, 05 Jan 2015 01:58:05 GMT Expires:Mon , 05 Jan 15 02:03:00 GMT Last-Modified:Mon, 05
- 数据源架构模式之行数据入口
home198979
PHP架构行数据入口
注:看不懂的请勿踩,此文章非针对java,java爱好者可直接略过。
一、概念
行数据入口(Row Data Gateway):充当数据源中单条记录入口的对象,每行一个实例。
二、简单实现行数据入口
为了方便理解,还是先简单实现:
<?php
/**
* 行数据入口类
*/
class OrderGateway {
/*定义元数
- Linux各个目录的作用及内容
pda158
linux脚本
1)根目录“/” 根目录位于目录结构的最顶层,用斜线(/)表示,类似于
Windows
操作系统的“C:\“,包含Fedora操作系统中所有的目录和文件。 2)/bin /bin 目录又称为二进制目录,包含了那些供系统管理员和普通用户使用的重要
linux命令的二进制映像。该目录存放的内容包括各种可执行文件,还有某些可执行文件的符号连接。常用的命令有:cp、d
- ubuntu12.04上编译openjdk7
ol_beta
HotSpotjvmjdkOpenJDK
获取源码
从openjdk代码仓库获取(比较慢)
安装mercurial Mercurial是一个版本管理工具。 sudo apt-get install mercurial
将以下内容添加到$HOME/.hgrc文件中,如果没有则自己创建一个: [extensions] forest=/home/lichengwu/hgforest-crew/forest.py fe
- 将数据库字段转换成设计文档所需的字段
vipbooks
设计模式工作正则表达式
哈哈,出差这么久终于回来了,回家的感觉真好!
PowerDesigner的物理数据库一出来,设计文档中要改的字段就多得不计其数,如果要把PowerDesigner中的字段一个个Copy到设计文档中,那将会是一件非常痛苦的事情。