[英]Inserting Node at the beginning of a linked list
我必须在链接列表的开头插入一个新的节点。 切换数据包后,我尝试用新数据覆盖第一个节点的数据。 但是,如果这样做,我的程序将更改第一个和第二个Node的数据值。
void insert(String iv_name, String iv_name_first, String iv_title, int iv_earning) {
if (this.first == null) {
this.first = new Node(new Data(iv_name, iv_name_first, iv_title, iv_earning, 0));
} else {
Node n = this.first;
Data last_n_data = getLast().data;
Data[] datas = new Data[getLast().data.getId()];
int j = 0;
while (n.next != null) {
datas[j] = n.data;
j++;
n = n.next;
}
j = 0;
n = this.first;
while (n.next != null) {
n.next.data = datas[j];
n.next.data.setId(datas[j].getId() + 1);
j++;
n = n.next;
}
n.next = new Node(new Data(last_n_data.getName_last(), last_n_data.getName_first(), last_n_data.getTitle(),
last_n_data.getEarning(), last_n_data.getId() + 1));
n.next.next = null;
this.first.data.setName_last(iv_name);
this.first.data.setName_first(iv_name_first);
this.first.data.setTitle(iv_title);
this.first.data.setEarning(iv_earning);
this.first.data.setId(0);
}
}
我认为您正在使这不必要地变得复杂。 要将链接列表插入到开头,您需要做的是:
void insert(String iv_name, String iv_name_first, String iv_title, int iv_earning) {
Node toCreate = new Node(new Data(iv_name, iv_name_first, iv_title, iv_earning, 0));
toCreate.next = this.first;
this.first = toCreate;
}
此代码仅创建一个新节点,使其成为新的第一个节点,并使其指向所有已经存在的节点。 因此,如果您有节点B-> C-> D,则最终结果将是A-> B-> C-> D
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.