Java 改写ArrayList的add方法让其变可以自动排序

这个是个作业,所以别告诉我有什么其他方法可以实现排序了,我改写的代码如下:importjava.util.*;publicclassSortedArrayList<Eex... 这个是个作业,所以别告诉我有什么其他方法可以实现排序了,我改写的代码如下:
import java.util.*;
public class SortedArrayList<E extends Comparable<E>> extends ArrayList<E>
{
public boolean add(E e)
{
if(size()==1)
{
add(0,e);
return true;
}
else{
add(e);
E value = e;
for(int x=size()-1; x>0; x--)
{
if (value.compareTo(get(x-1))>0)
{
break;
}
else
{
add(x-1, value);
}
}
return true;
}
}
}

代码没有报错,但是运行程序的时候出现了java,lang.StackOverflowError: null 的错误提示,求解答到底哪里错了。。
展开
 我来答
椰子猪啊
推荐于2018-03-13 · TA获得超过114个赞
知道小有建树答主
回答量:160
采纳率:0%
帮助的人:106万
展开全部
public static class SortedArrayList<E extends Comparable<E>> extends ArrayList<E>
{
public boolean add(E e)
{
if(size()==0)
{
add(0,e);
return true;
}
else{

E value = e;
int x=0;
for(x=size(); x>0; x--)
{

if (value.compareTo(get(x-1))>0)
{

break;
}
}
add(x,value);
return true;
}
}
}
你的写法会出现死循环 然后就溢出了 你调试下就能看到
改成这样就行了
如果要从大到小把 if (value.compareTo(get(x-1))>0)改成if (value.compareTo(get(x-1))<0)
追问
完美! 太感谢了
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2014-12-10
展开全部
else{

 add(e); //无限循环了.  如果要调用父类的需要加supper.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
优质内容提供者andy
2014-12-10 · TA获得超过1561个赞
知道大有可为答主
回答量:2551
采纳率:72%
帮助的人:752万
展开全部
你else里面可能add两次?而且这个add 一直递归
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
dark19861201
推荐于2017-12-16 · TA获得超过2152个赞
知道大有可为答主
回答量:2584
采纳率:79%
帮助的人:1776万
展开全部
这个是栈溢出,是你写法的问题,你用的递归,一旦数据了比较大,那么这么排序肯定会溢出的,建议你把排序代码修改一下
追问
那么应该怎么改呢?我都有点被自己绕糊涂了。。
追答
其实都不用你写逻辑Collections.sort()方法就行了,反正你的参数肯定是一个ArrayList,你先强转一下
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
阿鸡c
2014-12-10 · 超过21用户采纳过TA的回答
知道答主
回答量:83
采纳率:0%
帮助的人:43.2万
展开全部
Extends中间有空格!不提示吗?
追问
有的啊
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 3条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式