这一题题目有些长,不过这不影响它是一道水题。
题意描述:
题中描述了两种情况,当输入数据以'P'开头时,表示输入的是1~N的一个排列,要求输出每个数前面比该数大的数字的个数,输出结果时顺序为数字1的在前,数字N的在最后。第二种情况正好相反,给出每个数字前面比该数大的数字的个数,要求输出原序列。
第一种情况好说,主要是第二种情况。情况二的解法是按从后往前顺序确定原序列,即先确定数字N的位置,再确定数字N-1的位置……直到所有数字位置确定。期间主要是元素的插入操作。

posted @ 2012-08-02 16:19 小鼠标 阅读(221) | 评论 (0)编辑 收藏
二分查找,是一种针对有序序列的查找方式,每次迭代会缩小一半的查找范围,一次查找的时间复杂度为O(logN)。
简单说一下二分查找过程:在有序序列seq[]中找一个数n,假设这个序列的起始下标分别为a,b,mid=(a+b)/2,那么n要么就是seq[mid](n=seq[mid]),要么在mid左边(n<seq[mid]),要么在mid右边(n>seq[mid]),要么这个数根本不在seq[]中。

下面这道题是二分查找的典型应用:
zoj1101
题意描述:在给定整数序列(<=1000)中找出四个不同的数,使得三个数的和等于另外一个数。
直接用四层循环铁定超时,这里采用了一种拿空间换时间的方式。
假设有a+b+d=c,这等价于a+b=c-d,我们可以把所有的a+b存起来(<=10^6个),把所有的c-d也存起来(<=10^6个),当拿到每一个a+b时我们只需要在所有c-d的序列中查找就行了。先把c-d序列排序,排序时间复杂度O(NlogN),查找过程可以用二分,这样就不会超时啦。
以下是本题代码:
posted @ 2012-08-01 21:39 小鼠标 阅读(1044) | 评论 (0)编辑 收藏
今天写C代码的时候用到了字符串结束标记,猛然感觉有些陌生,索性复习一下C语言的转义字符。
转义字符——当然也是字符,引用的时候要加单引号。C语言中之说以会出现转义字符,无非处于以下几个原因:
1.有些字符是不可见的,无法通过键盘输入(比如换行符、回车符、响铃等)。
2.有些字符已经有特殊的用途,无法直接引用(比如:'\',单引号、双引号等)。
3.使用转义字符能够使意图更清楚(比如字符串结束标志,我们更倾向于写成'\0',而不是直接赋0值)。
下表列出了C语言中所有的转义字符:
转义字符 意义 ASCII码值(十进制)
\a 响铃(BEL) 007
\b 退格(BS) ,将当前位置移到前一列 008
\f 换页(FF),将当前位置移到下页开头 012
\n 换行(LF) ,将当前位置移到下一行开头 010
\r 回车(CR) ,将当前位置移到本行开头 013
\t 水平制表(HT) (跳到下一个TAB位置) 009
\v 垂直制表(VT) 011
\\ 代表一个反斜线字符''\' 092
\' 代表一个单引号(撇号)字符 039
\" 代表一个双引号字符 034
\0 空字符(NULL) 000
\ddd 1到3位八进制数所代表的任意字符 三位八进制
\xhh 1到2位十六进制所代表的任意字符 二位十六进制
posted @ 2012-07-31 23:09 小鼠标 阅读(1706) | 评论 (0)编辑 收藏
线段树题,本题对线段树的操作有建树(MakeTree())、查找(Query())、更新(update())。
建树一次完成,时间花费为O(LogN);查询的时间复杂度鄙人还不会分析O(∩_∩)O~,最坏可能是O(N),不过这种情况应该很难出现;更新的算法值得商榷,不同的策略时间复杂度会相差很大。下面讲解两种比较用以想到的更新策略。
更新方法一:
每次都将所有能更新的节点更新,这种方式最坏情况下将会更新树中所有节点,此时时间复杂度为O(N)。本题使用这种方法会TLE。
更新方法二:
每次都尽量少的更新节点信息,与第一种方法相比,Node内会多一个变量en,我把它形象的称之为“势能”,计算结果时要将该的所有父节点的“势能”也考虑在内。这种方法的时间复杂度也不好分析,但明显优于第一种方法。
这一题对时间卡的很紧,主要是花在树的更新上。
关于线段树可以先参阅:http://www.cppblog.com/hoolee/archive/2012/07/29/185531.html
以下是本题代码:

posted @ 2012-07-31 20:40 小鼠标 阅读(3610) | 评论 (0)编辑 收藏
即使是没有算法的题,也应该想清楚了再写,特别是关于字符串处理的,细节很多,稍不注意就会发生错误。
下面这道题是经典的“回文”题,要求输出每句话中每个单词的回文,但是单词在句子中的位置不变。

posted @ 2012-07-31 16:58 小鼠标 阅读(326) | 评论 (1)编辑 收藏

彻底的水题,因为没有说数据量,我把数组开小了,SF了四次,最后把数字串长

度开到4000才过,真是坑爹啊。


posted @ 2012-07-31 16:15 小鼠标 阅读(165) | 评论 (0)编辑 收藏
     摘要: 这是我写的第一道线段树,思路还算清晰,不过之前走了不少弯路。主要错在:误以为线段树是一棵满二叉树,建树时吃了苦头。//线段树除了最后一层可能不满足满二叉树性质外,上面的所有层构成完全二叉树,因此仍然可以用满二叉树的性质:如果树根节点从1开始编号,则对任意编号的节点t,左子树编号为t*2,右子树编号为t*2+1,父节点编号为t/2。这样,建树的时候节点内就不用记录儿子或父节点的信息了。下面结合poj...  阅读全文
posted @ 2012-07-29 10:44 小鼠标 阅读(1849) | 评论 (2)编辑 收藏
科学家发明了一种新的生物,这种生物能够两两合并,重量为m1的生物与重量为m2的生物合并后变为一个生物,该生物的重量为2*sqrt(m1*m2)。求给定数量的生物合并成一个生物后的最小重量。
贪心算法,每次选取重量最大的两个生物合并成一个即可。下面的代码是有优先队列(大顶堆)实现的。
不过,深入分析一下,由数学公式可以证明:m1+m2 >= 2*sqrt(m1*m2),因此当两个生物合并后,重量一定是剩余生物中最大的,由此只要将原重量按降序排序一次,然后依次合并即可。
优先队列有些大材小用了。

posted @ 2012-07-21 22:22 小鼠标 阅读(782) | 评论 (0)编辑 收藏
     摘要: 优先队列,其实我一直不愿承认“优先队列”是一种“队列”,现实世界的队列(比如排队)告诉我们,队列最明显的性质就是先进先出。而优先队列,似乎跟这个规则没什么关系……  阅读全文
posted @ 2012-07-20 10:36 小鼠标 阅读(3291) | 评论 (0)编辑 收藏
     摘要: 单调队列,顾名思义就是具有单调性的队列O(∩_∩)O~,一般的队列只能从队尾入队、队首出队;为了保持单调队列的单调性,单调队列除具有这两种性质外,还可以从队尾出队……  阅读全文
posted @ 2012-07-19 12:21 小鼠标 阅读(5480) | 评论 (0)编辑 收藏
仅列出标题
共13页: First 5 6 7 8 9 10 11 12 13 
<2024年11月>
272829303112
3456789
10111213141516
17181920212223
24252627282930
1234567

常用链接

随笔分类(111)

随笔档案(127)

friends

最新评论

  • 1. re: 线段树
  • 是这个样子的,所以在OJ有时候“卡住”了也不要太灰心,没准真的不是自己的原因呢。
    加油,祝你好运啦!
  • --小鼠标
  • 2. re: 线段树
  • 对于编程竞赛来说,Java所需时间一般为C/C++的两倍。合理的竞赛给Java的时间限制是给C/C++的两倍。
  • --伤心的笔
  • 3. re: poj1273--网络流
  • 过来看看你。
  • --achiberx
  • 4. re: (转)ubuntu11.10无法启动无线网络的解决方法
  • 膜拜大神。。查了一个下午资料终于在这里解决了问题。。神牛说的区域赛难道是ACM区域赛。。?
  • --Hang
  • 5. re: 快速排序、线性时间选择
  • 博主,谢谢你的文章。你的方法可以很好的处理分区基准在数组中重复的情况,书上的方法遇到这种输入会堆栈溢出。书上给出了解释但给的方法貌似不简洁。
  • --lsxqw2004

阅读排行榜