单链表的特点是只能从头开始向后遍历,所以我们在增删查改的过程中都要考虑从头开始的问题,单链表的临界情况是对于头结点的操作,我们需要对头节点多加考虑。
通过画图来解决单链表的基本操作
-
头部插入 data:image/s3,"s3://crabby-images/74ac8/74ac88f18414c9e930fc6bdabad76e3911899f72" alt="在这里插入图片描述" -
中间位置插入 data:image/s3,"s3://crabby-images/f6dbf/f6dbf8c8512cbf89c20cad1f8a766f915db88ee9" alt="在这里插入图片描述" -
删除头结点 data:image/s3,"s3://crabby-images/d165d/d165df99c759185c7c0071a9a9fd13fae04f674f" alt="在这里插入图片描述" -
删除中间结点 data:image/s3,"s3://crabby-images/999ae/999ae1461369c6bdbae2f989d6384ffdf7015cf3" alt="在这里插入图片描述" -
查找结点 data:image/s3,"s3://crabby-images/c908d/c908d306a12798b3c7aa240fa07721242ff643a4" alt="在这里插入图片描述" -
修改结点 data:image/s3,"s3://crabby-images/06a7b/06a7bf423a0897a73c16dbc147489706b48ae605" alt="在这里插入图片描述" 代码实现这些功能
class NodePractice{
int data;
NodePractice next;
public NodePractice(int data) {
this.data = data;
}
}
public class SingleLinkedListPractice {
int size;
NodePractice head;
public void addFirst(int data)
{
NodePractice nodePractice=new NodePractice(data);
if(size==0)
{
head=nodePractice;
size++;
}
else
{
nodePractice.next=head;
head=nodePractice;
size++;
}
}
public void addIndex(int index,int data){
if(index < 0 || index > size)
{
System.out.println("index illegal");
return;
}
if(index==0)
{
addFirst(data);
return;
}
NodePractice prev=head;
for (int i = 0; i < index-1; i++) {
prev=prev.next;
}
NodePractice nodePractice=new NodePractice(data);
nodePractice.next=prev.next;
prev.next=nodePractice;
size++;
}
public void addLast(int data)
{
addIndex(size,data);
}
public boolean checkIndex(int index){
if(index < 0 || index >size-1)
{
System.out.println("index illegal");
return false;
}
return true;
}
public void removeIndex(int index){
if(checkIndex(index))
{
if(index==0)
{
NodePractice nodePractice=head;
head=head.next;
nodePractice.next=null;
size--;
return;
}
else
{
NodePractice prev=head;
for (int i = 0; i < index-1; i++) {
prev=prev.next;
}
NodePractice nodePractice=prev.next;
prev.next=nodePractice.next;
nodePractice.next=null;
size--;
}
}
}
public boolean checkData(int data) {
NodePractice nodePractice=head;
for (int i = 0; i < size; i++) {
if(nodePractice.data==data)
{
return true;
}
nodePractice=nodePractice.next;
}
return false;
}
public void removeFirstData(int data)
{
if(checkData(data))
{
if(head.data==data)
{
removeIndex(0);
}
NodePractice prev=head;
while (prev.next != null)
{
if(prev.next.data==data)
{
NodePractice nodePractice=prev.next;
prev.next=nodePractice.next;
nodePractice.next=null;
size--;
return;
}
}
}
}
public void removeAllData(int data){
while (head != null && head.data==data)
{
NodePractice nodePractice=head;
head=head.next;
nodePractice.next=null;
size--;
}
if(head == null)
{
return;
}
NodePractice prev=head;
while (prev.next != null)
{
if(prev.next.data==data)
{
NodePractice nodePractice=prev.next;
prev.next=nodePractice.next;
nodePractice.next=null;
size--;
}
else
{
prev=prev.next;
}
}
}
public int seekIndex(int index){
if(checkIndex(index))
{
NodePractice nodePractice=head;
for (int i = 0; i < index; i++) {
nodePractice=nodePractice.next;
}
return nodePractice.data;
}
return -1;
}
private int count;
public int seekData(int data){
NodePractice nodePractice=head;
for (int i = 0; i < size; i++) {
if(nodePractice.data==data)
{
System.out.println("找到了");
return count;
}
nodePractice=nodePractice.next;
count++;
}
System.out.println("没找到");
return -1;
}
public void setIndex(int index,int data){
if(checkIndex(index))
{
NodePractice nodePractice=head;
for (int i = 0; i < index; i++) {
nodePractice=nodePractice.next;
}
nodePractice.data=data;
}
}
public void setData(int oleData, int newData){
if(checkData(oleData))
{
NodePractice nodePractice=head;
for (int i = 0; i < size; i++) {
if(nodePractice.data==oleData)
{
nodePractice.data=newData;
}
nodePractice=nodePractice.next;
}
}
}
@Override
public String toString() {
String ret="";
NodePractice nodePractice=head;
for (int i = 0; i < size; i++) {
ret+=nodePractice.data+"->";
nodePractice=nodePractice.next;
}
ret+="NULL";
return ret;
}
public static void main(String[] args) {
SingleLinkedListPractice singleLinkedListPractice=new SingleLinkedListPractice();
singleLinkedListPractice.addFirst(9);
singleLinkedListPractice.addFirst(7);
singleLinkedListPractice.addFirst(5);
singleLinkedListPractice.addFirst(3);
singleLinkedListPractice.addFirst(3);
singleLinkedListPractice.addFirst(3);
singleLinkedListPractice.addFirst(1);
singleLinkedListPractice.addFirst(3);
singleLinkedListPractice.addFirst(3);
singleLinkedListPractice.addFirst(3);
System.out.println(singleLinkedListPractice);
singleLinkedListPractice.setData(3,6);
System.out.println(singleLinkedListPractice);
}
}
|