向创建的List里面添加数据时,所有数据均被最后输入的数据覆盖

 

        List<Student> stu=new ArrayList<Student>();

stu为声明的一个元素类型为Student的ArrayList对象。

就像上面那段这样,明明我在for循坏里面向stu添加了两个元素,但是输出却均是我第二次输入的元素。

究其原因,是这个temp类型的对象声明在了for循环之外!

那问题就来了。List里面的add()接口其本质上是对添加的元素进行引用操作,也就是说我向stu里面添加的每一个元素都是通过访问temp地址来进行stu的修改。拿上面那个例子来说,由于stu【0】(姑且这么说)是通过temp进行修改的,temp直接指向这个元素。当给stu【1】进行赋值的时候,现在stu【0】还是由temp指向的,同时stu【1】也是由temp指向。这时的temp确实是我们当前输入的值,stu【1】也是我们希望得到的值。但是由于stu【0】也是和temp挂钩的,所以它也会变成当前temp的值。

以此类推,输入stu【2】时,stu【0】和stu【1】原有的值也会随之temp的改变而改变。

解决此问题的方法是:把temp放在for循环里面

        for(i=0;i<n;i++){
            Student temp=new Student();//建立一个临时对象

            name[i]=sc.next();
            temp.setName(name[i]);
            number[i]=sc.nextInt();
            temp.setNumber(number[i]);
            age[i]=sc.nextInt();
            temp.setAge(age[i]);
            grade[i]=sc.nextDouble();
            temp.setGrade(grade[i]);
            stu.add(temp);

        }

这样的话temp就不再是一个固定的地址,而是每循环一次就会有一个新的地址。

stu【0】、stu【1】里面的值均是由不同地址的temp指向,这样新的temp只会和当前stu的元素挂钩。

得到结果也就是和我们想的一样。

 

创建一个顺序表数据结构,通常会使用数组作为底层存储,来实现插入、删除操作。这里是一个简单的步骤说明: 1. **初始化顺序表**:首先创建一个固定大小的数组(比如`size`),用于存储学生的学号。 ```python class SequenceList: def __init__(self, capacity): self.data = [0] * capacity self.length = 0 ``` 2. **添加学生(插入)**:当需要插入新学号到第7位,首先要确保有足够的空间。如果已满,则需动态扩容。然后将新学号放置到适当位置。 ```python def insert(self, new_student): if self.length == len(self.data): self.resize() old第七位 = self.data[self.length - 7] for i in range(self.length - 6, -1, -1): # 从倒数第二个元素开始向左移动 self.data[i + 1] = self.data[i] self.data[6] = new_student self.length += 1 def resize(self): new_capacity = self.capacity * 2 # 可能的扩容因子 new_data = [0] * new_capacity for i in range(self.length): new_data[i] = self.data[i] self.data = new_data self.capacity = new_capacity ``` 3. **删除学生(删除)**:删除第七位的学生同样要考虑空间溢出的情况。从第六位开始向前填充,最后一位的数据会被覆盖。 ```python def delete(self, position): if position >= 7 and position < self.length: for i in range(position, self.length - 1): self.data[i] = self.data[i + 1] self.length -= 1 elif position == self.length: # 如果试图删除最后一个位置,不做处理,因为没有下一个位置可以填补 pass ``` 4. **删除第七位**:调用 `delete(7)` 即可。 请注意,这个实现假设学号的长度固定,并且索引从0开始计数。实际应用中,可能需要更复杂的方式来处理不固定长度的学号以及边界条件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值