#include<iostream>
using namespace std;
typedef struct Link_Node{
int data;
Link_Node* next;
} ;
// 单链表的插i入操作,插入到第K个元素后面,link_list 是单链表的首指针
// 有可能List,
int insert_data(Link_Node *link_list,int k,int data)
{
Link_Node *p_node = link_list;
int i = 0;
while(p_node&&i<k){
i++;
p_node = p_node->next;
}
if(!p_node) return 0; // 没有第K个元素,插入位置无效
// 已经到了第k个元素,把新值放在第K 个值 后面。
//p_node 是第K个节点,将data放在 p_node 之后。
Link_Node *next_k_node = (Link_Node*)malloc(sizeof(Link_Node));
next_k_node->next = p_node->next;
next_k_node->data = data;
p_node->next = next_k_node;
return 1;
}
int delete_data(Link_Node *link_list,int k)
{
int i = 0;
Link_Node *p_node = link_list;
while(p_node&&i<k-1){
i++;
p_node = p_node->next;
}
if(!p_node&&!p_node->next) return 0; //没有第K个元素,插入位置无效
Link_Node *del_node = p_node->next;
p_node->next = del_node->next;
free(del_node);
return 1;
}
int main()
{
Link_Node *p = (Link_Node*)malloc(sizeof(Link_Node)); // 头结点
Link_Node *current = p;
for(int i = 0 ; i <10 ;i++){
Link_Node *p_node = (Link_Node*)malloc(sizeof(Link_Node));
p_node->data = i;
p_node->next = NULL;
current->next = p_node;
current = current->next;
}
insert_data(p,10,10);
current = p;
while(current=current->next){
cout<< current->data<<endl;
}
delete_data(p,9);
current = p;
while(current=current->next){
cout<<current->data<<endl;
}
insert_data(p,8,8);
current = p;
while(current=current->next){
cout<<current->data<<endl;
}
return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。