Skip to content

Commit

Permalink
Merge pull request wangzheng0822#1 from wangzheng0822/master
Browse files Browse the repository at this point in the history
Merge from original trunk
  • Loading branch information
chinalwb authored Oct 8, 2018
2 parents 04c7c20 + c834a02 commit 49c2b7f
Show file tree
Hide file tree
Showing 13 changed files with 1,691 additions and 51 deletions.
229 changes: 229 additions & 0 deletions c-cpp/06_linkedlist/LRUBasedLinkedList.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,229 @@
typedef int DataType;

//定义
class SNode
{
public:
DataType data;
SNode * next;
};

class SList
{
public:
SList();
SList(int MaxSize);
~SList();
void intsertElemAtBegin(DataType x); //头部插入节点
bool findElem(DataType x); //查找x,存在则返回1,不存在则返回0
void deleteElemAtEnd(); //删除尾节点
bool deleteElem(DataType x); //删除指定节点,如果存在则删除,返回1,如果不存在,则删除失败返回0
bool isEmpty(); // 查看链表是否为空,1表示不为空,0表示为空
bool isFull(); // 查看链表是否满,1表示不满,0表示满
void printAll();

void * findElemOptim(DataType x); //针对此应用的优化,查找,返回指定元素的前一个节点的指针
void deleteElemOptim(void * snode); //针对此应用的优化,删除
private:
int MaxSize; // 链表可以存放最大的数据
int length; // 链表的长度
SNode * head; // 指向头节点

};


/**
* 1)单链表的插入,删除,查找操作;
* 2)链表中存储的是 int 类型
*
* Author:caozx
*/
#include<iostream>
using namespace std;

// 初始化单链表
SList::SList(){
head = new SNode; //申请头节点
head -> next = NULL;
this -> MaxSize = 10;
this -> length = 0;
}
SList::SList(int MaxSize){
head = new SNode; //申请头节点
head -> next = NULL;
this -> MaxSize = MaxSize;
this -> length = 0;
}

// 销毁单链表,要把开辟的空间都释放,然后再销毁。
SList::~SList(){
SNode * ptr, * temp;
ptr = head;
while(ptr -> next != NULL){
temp = ptr -> next;
ptr -> next = ptr -> next -> next;
delete temp;
}
delete head ; //删除头节点
this -> head = NULL;
this -> length = 0;
}

//链表头部插入节点
void SList::intsertElemAtBegin(DataType x){
SNode * ptr = new SNode;
ptr -> data = x;

ptr -> next = head ->next;
head -> next = ptr;

this -> length ++;
}

//查找x,存在则返回1,不存在则返回0

bool SList::findElem(DataType x)
{
SNode * ptr;
ptr = head;
while(ptr -> next != NULL){
if(ptr -> next ->data == x){
return 1;
}
ptr = ptr -> next;
}
return 0;
}

// 删除尾结点
void SList::deleteElemAtEnd(){
SNode * ptr , * temp;
ptr = head;
while(ptr -> next != NULL && ptr -> next -> next != NULL){ //倒数第二个节点
ptr = ptr -> next;
}
temp = ptr -> next;
ptr -> next = temp -> next;
this -> length --;
delete temp;
}

//删除指定节点,
//如果存在则删除,返回1,表示存在且删除成功;
//如果不存在则不删除,返回0,表示不存在该元素,不需要删除,也即删除失败
bool SList::deleteElem(DataType x)
{
SNode * ptr, * temp;
ptr = head;
while(ptr -> next != NULL){
if(ptr -> next ->data == x){
temp = ptr -> next;
ptr -> next = temp -> next;
delete temp;
this -> length --;
return 1;
}
ptr = ptr -> next;
}
return 0;
}

// 查看链表是否为空,1表示不为空,0表示为空
bool SList::isEmpty()
{
if(this -> length == 0){ //
return 0;
}
else{
return 1;
}
}

// 查看链表是否满,1表示不满,0表示满
bool SList::isFull()
{
if(this -> length == this -> MaxSize){ //
return 0;
}
else{
return 1;
}
}

// 打印
void SList::printAll()
{
SNode * ptr;
ptr = head;
while(ptr -> next != NULL){
ptr = ptr -> next;
cout << ptr-> data <<" ";
}
cout << endl;
}

//针对此应用的优化,查找,
//若存在则返回指定元素的前一个节点的指针
//若不存在,则返回NULL

void * SList::findElemOptim(DataType x)
{
SNode * ptr;
ptr = head;
while(ptr -> next != NULL){
if(ptr -> next ->data == x){
return (void *)ptr;
}
ptr = ptr -> next;
}
return NULL;
}

//针对此应用的优化,删除

void SList::deleteElemOptim(void * snode)
{
SNode * ptr, * temp;
ptr = (SNode *)snode;
temp = ptr -> next;
ptr -> next = temp -> next;
this -> length --;
delete temp;
}
int main(int argc, char const *argv[])
{
cout << "test "<< endl;
SList slist(10); //缓存最大10个。
int num = 0;
while(1)
{
cout << "please enter a number,99999== exit" << endl;
cin >> num;
if(num == 99999)
break;
/* 未优化
if(slist.findElem(num)){ //存在
slist.deleteElem(num); //把原来的位置删除
slist.intsertElemAtBegin(num); //在链表头插入
}
*/
//优化
SNode * prePtr = (SNode *)slist.findElemOptim(num);
if(prePtr != NULL){ //存在
slist.deleteElemOptim(prePtr); //把原来的位置删除
slist.intsertElemAtBegin(num); //在链表头插入
}
else{ //不存在
if(slist.isFull()){ //不满
slist.intsertElemAtBegin(num);
}
else{ //
slist.deleteElemAtEnd();
slist.intsertElemAtBegin(num);
}
}
slist.printAll();
}
return 0;
system("pause");
}
15 changes: 7 additions & 8 deletions c-cpp/06_linkedlist/single_list.c
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ void insert_head(struct single_list_head *head, struct single_list *elem)
insert(&head->head, elem);
}

struct single_list* delete(struct single_list **prev)
struct single_list* del(struct single_list **prev)
{
struct single_list *tmp;

Expand All @@ -53,12 +53,12 @@ struct single_list* delete(struct single_list **prev)
tmp->next = NULL;

return tmp;
}
};

struct single_list* delete_head(struct single_list_head* head)
{
return delete(&head->head);
}
return del(&head->head);
};

struct single_list** search(struct single_list_head* head, int target)
{
Expand All @@ -70,7 +70,7 @@ struct single_list** search(struct single_list_head* head, int target)
;

return prev;
}
};

void reverse(struct single_list_head* head)
{
Expand Down Expand Up @@ -117,7 +117,7 @@ struct single_list* middle(struct single_list_head* head)
}

return NULL;
}
};

int main()
{
Expand Down Expand Up @@ -153,7 +153,7 @@ int main()
else
printf("The list not contains 2\n");

delete(prev);
del(prev);
prev = search(&head, 2);
printf("After remove 2\n");
if ((*prev) && ((*prev)->val == 2))
Expand All @@ -173,4 +173,3 @@ int main()

return 0;
}

Loading

0 comments on commit 49c2b7f

Please sign in to comment.