写了一个快速排序算法,运行后提示数组下表越界,之前用C写的运行无错误,改成JAVA后就出现了这个,求大神解答,谢谢

_初级程序猿 2015-06-30 10:55:51
import java.util.Arrays;

public class SortQuick {
public static void main(String [] args){
int a[] = {5,7,1,4,2,3,10,9,6,8};
mySort(a,0,(a.length-1));
System.out.println(Arrays.toString(a));
}
public static void mySort(int a[],int left,int right)
{
int key = a[left];
int i = left;
int j = right;
if(left>right)
{
return;
}
while(i<j)
{
while(i<j&&a[j]>=key)
{
j--;
}
while(i<j&&a[i]<=key)
{
i++;
}
if(i<j)
{
int t = a[j];
a[j] = a[i];
a[i] = t;
}
}
a[left] = a[j];
a[j] = key;
mySort(a,left,j-1);
mySort(a,j+1,right);
}
}
...全文
83 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
Inhibitory 2015-06-30
  • 打赏
  • 举报
回复
mySort(a,j+1,right); j 为 right 的时候且为 a.length - 1 是,j+1为 a.length,int key = a[left]; 就越界了
代码下载地址: https://pan.quark.cn/s/692a61fb005f HTML(超文本标记语言)是一种构建网页的标准化标记语言,它构成了网页设计的核心,使得开发者能够通过文本、图像、视频等媒介创建交互式的用户界面。在名为"HTML淘宝网页"的项目中,我们可以研究HTML在模拟知名电子商务平台——淘宝网上的实际应用,以及相关的前端开发技术。HTML页面的构造通常包含头部(head)和主体(body)两个主要部分。在头部部分,开发者会加载CSS(层叠样式表)和JavaScript文件,这些文件用于调控页面的外观和交互功能。在"淘宝网页"的开发过程中,开发者或许运用了内联样式、内部样式表或外部样式表来设定页面的视觉表现,使其与淘宝网站的风格相吻合。主体部分是展示网页内容的核心区域,其中包含了多种HTML组件,例如`
`(页头)、`

51,411

社区成员

发帖
与我相关
我的任务
社区描述
Java相关技术讨论
javaspring bootspring cloud 技术论坛(原bbs)
社区管理员
  • Java相关社区
  • 小虚竹
  • 谙忆
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧