- 浏览: 109485 次
- 性别:
- 来自: 广州
最新评论
-
xinhemei:
我试了试,发现gmail和163的不行。好像ajax请求失败了 ...
jQuery实现邮箱自动登录 -
酒鬼_yuan:
我正在找 谢谢了
关于yui的学习
package easy;
import java.io.BufferedInputStream;
import java.util.Scanner;
/**
*poj2388
* 排一次序后输出中位数,但效率太低了。
* 用计数排序可能好一点,当找到中位数就可以停止排序了。
* @author NC
*/
public class Poj2388 {
public static void main(String[] args) {
Scanner scan = new Scanner(new BufferedInputStream(System.in));
if (scan.hasNext()) {
int n = scan.nextInt();
int[] array = new int[n + 1];
for (int i = 0; i < n; i++) {
array[i + 1] = scan.nextInt();
}
quickSort(array);
System.out.println(array[n / 2 + 1]);
}
}
private static int partition(int[] array, int low, int high) {
int key = array[low]; //用子表的第一个记录作为枢轴记录
while (low < high) {//从表的两端交替地向中间扫描
while (low < high && array[high] >= key) {//比枢轴记录大的话,位置正确,移动下标
high--; //下标从高端向中间扫描
}
array[low] = array[high]; //把比枢轴记录小的记录交换到低端,(这里先从直接赋值,和下面的一起才算交换)
while (low < high && array[low] <= key) {//比枢轴记录小的话,位置正确,移动下标
low++; //下标从低端向中间扫描
}
array[high] = array[low]; //把比枢轴记录大的记录交换到高端,(这里赋值回去,和上面的一起才算交换)
}
array[low] = key; //枢轴记录到位
return low;
}
private static void qSort(int[] array, int low, int high) {
int pivotloc;
if (low < high) {//保证长度大于1,递归的出口
pivotloc = partition(array, low, high); //将表low-high一分为2,用枢轴位置来分
qSort(array, low, pivotloc - 1); //对低子表递归排序
qSort(array, pivotloc + 1, high); //对高子表递归排序
}
}
public static void quickSort(int[] array) {
int n = array.length - 1;
qSort(array, 1, n);
}
}
import java.io.BufferedInputStream;
import java.util.Scanner;
/**
*poj2388
* 排一次序后输出中位数,但效率太低了。
* 用计数排序可能好一点,当找到中位数就可以停止排序了。
* @author NC
*/
public class Poj2388 {
public static void main(String[] args) {
Scanner scan = new Scanner(new BufferedInputStream(System.in));
if (scan.hasNext()) {
int n = scan.nextInt();
int[] array = new int[n + 1];
for (int i = 0; i < n; i++) {
array[i + 1] = scan.nextInt();
}
quickSort(array);
System.out.println(array[n / 2 + 1]);
}
}
private static int partition(int[] array, int low, int high) {
int key = array[low]; //用子表的第一个记录作为枢轴记录
while (low < high) {//从表的两端交替地向中间扫描
while (low < high && array[high] >= key) {//比枢轴记录大的话,位置正确,移动下标
high--; //下标从高端向中间扫描
}
array[low] = array[high]; //把比枢轴记录小的记录交换到低端,(这里先从直接赋值,和下面的一起才算交换)
while (low < high && array[low] <= key) {//比枢轴记录小的话,位置正确,移动下标
low++; //下标从低端向中间扫描
}
array[high] = array[low]; //把比枢轴记录大的记录交换到高端,(这里赋值回去,和上面的一起才算交换)
}
array[low] = key; //枢轴记录到位
return low;
}
private static void qSort(int[] array, int low, int high) {
int pivotloc;
if (low < high) {//保证长度大于1,递归的出口
pivotloc = partition(array, low, high); //将表low-high一分为2,用枢轴位置来分
qSort(array, low, pivotloc - 1); //对低子表递归排序
qSort(array, pivotloc + 1, high); //对高子表递归排序
}
}
public static void quickSort(int[] array) {
int n = array.length - 1;
qSort(array, 1, n);
}
}
发表评论
-
Poj3126
2010-05-29 22:07 1233import java.io.BufferedIn ... -
poj3125简单模拟
2010-05-25 11:44 1004import java.io.BufferedInputS ... -
还是水
2010-05-24 12:53 767import java.io.BufferedInputS ... -
Poj3085再水一下
2010-05-24 12:28 864import java.io.BufferedInputS ... -
Poj3673超水题
2010-05-24 12:12 867package easy; import java. ... -
Poj3278 广度优先搜索
2010-05-22 23:24 1330import java.io.BufferedInputS ... -
合唱队形
2010-05-09 21:45 2165#include <stdio.h> #incl ... -
动态规划经典问题 石子合并
2010-05-09 21:45 6102我们学校的oj的 #include & ... -
poj3199 高精
2010-05-09 21:44 967import java.io.BufferedInputS ... -
poj1002 郁闷的电话号码
2010-05-08 23:48 1280import java.io.BufferedInputS ... -
poj1298 无语。。。
2010-04-24 23:24 1018import java.io.BufferedInputStr ... -
poj1017 装箱问题 简单贪心
2010-04-18 16:56 2356import java.io.BufferedInpu ... -
poj1042 枚举+贪心算法
2010-04-18 00:45 1800import java.io.BufferedInputS ... -
zoj3197 Google Book 贪心算法
2010-04-15 23:54 1394#include <stdio.h> #defi ... -
Poj2453 an easy program
2010-04-09 00:19 870/* * To change this template, ... -
poj2299 递归与分治策略
2010-04-02 23:38 1438package hard; import java.io ... -
poj1723 数学问题
2010-04-02 15:31 1035package middle; import jav ... -
Poj2524 并查集
2010-03-18 15:22 864package middle; import jav ... -
Poj1308 并查集
2010-03-18 15:21 1708package middle; import jav ... -
poj1405 高精
2010-02-28 11:09 1375import java.io.BufferedInputS ...
相关推荐
《POJ2388-Who's in the Middle》是一个典型的计算机编程竞赛题目,主要考察参赛者的算法设计和实现能力。这个题目源自北京大学的在线评测系统POJ(PKU Online Judge),是编程爱好者和学生提升编程技能的重要平台之...
这个练习题目,"POJ 2388",显然是通过编程实现直接插入排序来解决一个特定的问题。在这个问题中,我们需要理解直接插入排序的机制,并能用Java语言编写出高效的代码。 直接插入排序的基本步骤如下: 1. 从第二个...
标题“堆排序练习:POJ 2388”指的是一个关于使用堆排序算法解决编程竞赛问题的实践案例。在编程竞赛中,如POJ(Programming Online Judge)平台上的问题2388,参赛者经常需要高效地解决排序问题,而堆排序作为一种...
* 排序:例如 poj2388、poj2299。 * 简单并查集的应用。 * 哈希表和二分查找等高效查找法:例如 poj3349、poj3274、poj2151、poj1840、poj2002、poj2503。 * 哈夫曼树:例如 poj3253。 * 堆:例如 poj2513。 *...
- 排序算法:如快速排序和归并排序,用于对数据进行排序,如`poj2388, poj2299`。 - 并查集:用于处理集合的合并和查询操作,如`poj3349, poj3274`。 - 哈希表:用于高效的数据查找,如`poj2151, poj1840`。 - ...
2. **堆**:堆排序及其在优先队列中的应用(poj2388, poj2299)。 3. **哈希表**:用于快速查找和存储,如Hash函数的设计(poj3349, poj3274, POJ2151, poj1840, poj2002, poj2503)。 4. **字符串处理**:Trie树...
- **例题**:poj2388, poj2299 - **解释**:字符串问题通常涉及字符串的模式匹配、编辑距离等问题。 #### 3. 哈希表 - **例题**:poj3349, poj3274, POJ2151, poj1840, poj2002, poj2503 - **解释**:哈希表是一种...
快速排序、归并排序和堆排序等,不仅用于排序,也常用于解决与逆序数相关的问题,如poj2388。 #### 并查集 用于处理集合的合并与查询操作,如poj3349所示。 #### 哈希表 高效查找数据的工具,利用哈希函数将数据...
- **排序算法**:包括快速排序、归并排序和堆排序,如poj2388,优化查找效率。 - **并查集**:用于处理集合合并与查询问题。 - **哈希表和二分查找**:提高查找效率,如poj3349,用于快速定位元素。 - **哈夫曼...
- (poj2388, poj2299):介绍二叉树、平衡二叉树等。 3. **字符串处理**: - (poj3349, poj3274, POJ2151, poj1840, poj2002, poj2503):字符串操作算法,如哈希函数的使用、模式匹配算法等。 4. **集合和映射**...
poj1035、poj3080等训练了串的操作,poj2388、poj2299等则涉及排序问题,poj2524、poj1611等是并查集的实例,poj3349、poj3274等展示了哈希表和二分查找,poj3253是哈夫曼树的题目,poj2442和poj1442则关于堆。...
- 推荐题目:[poj2388](https://vjudge.net/problem/POJ-2388)、[poj2299](https://vjudge.net/problem/POJ-2299) - 并查集用于处理不相交集合的合并及查询问题。 3. **哈希表** - 推荐题目:[poj3349]...
- poj2388 - poj2299 - **应用场景**:适用于数据组织和分析。 **3. 并查集** - **定义**:一种用于处理一些不交集的合并及查询问题的数据结构。 - **示例题目**: - poj1703 - poj1988 - poj2524 - poj2492 ...
2. **排序**:包括快速排序、归并排序(涉及逆序数)、堆排序,如POJ2388、2299。 3. **并查集**:处理集合合并和查询问题。 4. **哈希表** 和 **二分查找**:提供高效查找能力,如POJ3349、3274、2151、1840、2002...
- **示例题目**: poj2388, poj2299 #### 3. 字典树 - **内容**: 字典树是一种高效的数据结构,主要用于存储字符串集合。 - **示例题目**: poj2513 - **知识点**: - **字典树的特点**:节省空间;查询速度快;方便...
+ poj2388, poj2299 * 简单并查集的应用 * 哈希表和二分查找等高效查找法 + poj3349, poj3274, poj2151, poj1840, poj2002, poj2503 * 哈夫曼树:poj3253 * 堆 * Trie树:静态建树、动态建树 + poj2513 四、简单...
例如,POJ1035和POJ3080是串的经典例题,而POJ2388和POJ2299则是排序算法的代表题。 在简单搜索部分,涵盖了深度优先搜索和广度优先搜索两种搜索算法。例如,POJ2488和POJ3083是深度优先搜索的经典例题,而POJ3278...
2. 排序:快速排序、归并排序(涉及逆序数)和堆排序,如poj2388、poj2299。 3. 并查集:处理集合合并与查询,如poj3349。 4. 哈希表和二分查找:快速查找,如poj3274、poj2151等。 5. 哈夫曼树:用于压缩编码,如...
排序算法如快排、归并排和堆排,例如 poj2388 和 poj2299。哈希表和二分查找在 poj3349 等题目中体现其效率。trie 树在 poj2513 中有应用。 搜索策略包括深度优先搜索(DFS)和广度优先搜索(BFS),如 poj2488 和 ...