| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 713 人关注过本帖
标题:JAVA快速排序问题!!!
只看楼主 加入收藏
zfzfzfzfln
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2008-1-18
收藏
 问题点数:0 回复次数:0 
JAVA快速排序问题!!!
这是我自己写的快速排序程序,为什么总是说我数组越界呢?
高手帮帮忙。
public class 快速排序 {

/**
* @param args
*/
public static void main(String[] args) {
System.out.print("请输入10个数字(输入每个数字后以回车结束):");
Scanner sc=new Scanner(System.in);
int[] a=new int[10];
int i;
for (i=0;i<10;i++)
a[i]=sc.nextInt();
QuickSort(a,0,a.length-1);
for (i=0;i<10;i++)
{
System.out.print(i+":"+a[i]+" ");
}
// TODO Auto-generated method stub

}

public static void QuickSort(int d[],int p,int q)
{
int mid=(p+q)/2;
int m=p;
int n=q;
int temp;
do
{
while(d[m]<d[mid]) m++;
while(d[n]>d[mid]) n--;                  这里会报错
if (m<n)
{
temp=d[n];
d[n]=d[m];
d[m]=temp;
}
m++;
n--;
}while(m>=n);
if (p<n) QuickSort(d,p,n);
if (q>m) QuickSort(d,m,q);                这里也会。
}
}

为什么?...
搜索更多相关主题的帖子: JAVA 
2008-10-12 19:59
快速回复:JAVA快速排序问题!!!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.022416 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved