zoukankan      html  css  js  c++  java
  • 数据结构链表学习

      今天初步学习数据结构链表,学习过程中感觉对于指针的理解还差很多,而且对于VS的调试也不会使用,调查问题只能靠一遍一遍的梳理逻辑,效率不是一般的低下。。接下来得赶紧学习下VS的使用。。

      今天链表只是初步学习,写的例子也比较简单,如下: 

    定义链表的数据结构,只简单的定义了一个数据和一个指向后继的指针

    1 struct List {
    2     int num;
    3     List *next;
    4 };

    接下来就是链表的创建,返回一个指针地址赋给主函数中的头指针,用于之后的增删改查等等

     1 List *create(int n) {
     2     List *p = new List;
     3     p->next = NULL;
     4     for(int i=0;i<n;i++) {
     5         List *myList = new List;
     6         cin>>myList->num;
     7         myList->next = p->next;
     8         p->next = myList;
     9     };
    10     return p->next;
    11 };

    然后是删除、插入以及输出函数,不在赘述:

     1 void print(List *p,int n) {
     2     for (int i=0;i<n;i++) {
     3         cout<<p->num<<endl;
     4         p = p->next;
     5     }
     6 };
     7 
     8 List *del(List *p,int n,int delNum) {
     9     List *first = p;
    10     List *previous;
    11     for (int i=0;i<n;i++) {
    12         if(p->num == delNum) {
    13             if (i == 0) {
    14                 first = p->next;
    15                 break;
    16             } else {
    17                 previous->next = p->next;
    18                 break;
    19             }
    20         } else {
    21             previous = p;
    22             p = p->next;
    23         }
    24     }
    25     return first;
    26 };
    27 
    28 List *insert(List *p,int n,int insNum,List *insList) {
    29     List *first = p;
    30     for (int i=0;i<n;i++) {
    31         if(p->num == insNum) {
    32             insList->next = p->next;
    33             p->next = insList;
    34             break;
    35         } else {
    36             p = p->next;
    37         }
    38     }
    39     return first;
    40 };

    最后是我们的main函数:

     1 typedef int INTER;
     2 int main() {
     3     List *create(INTER);
     4     void print(List *,INTER);
     5     List *del(List *,INTER,INTER);
     6     List *insert(List *,INTER,INTER,List *);
     7     cout<<"List Study ---------> List create."<<endl;
     8     List *first = NULL;
     9     INTER n = 5;
    10     first = create(n);
    11     print(first,n);
    12     cout<<"List Study ---------> List delete."<<endl;
    13     INTER delNum;
    14     cin>>delNum;
    15     first = del(first,n,delNum);
    16     n--;
    17     print(first,n);
    18     cout<<"List Study ---------> List insert."<<endl;
    19     INTER insNum;
    20     cin>>insNum;
    21     List insList = {15,NULL};
    22     first = insert(first,n,insNum,&insList);
    23     n++;
    24     print(first,n);
    25     cout<<"List Study ---------> List end."<<endl;
    26     system("pause");
    27     return 0;
    28 };

    如此,一个简单的链表就实现了,功能只有简单的输出、删除和插入,只是练习用,因此插入和删除中并未进行任何的容错处理。

  • 相关阅读:
    Objective-C Loops
    HDU 4757 Tree(可持久化Trie+Tarjan离线LCA)
    Codeforces Round #367 (Div. 2) D. Vasiliy's Multiset(可持久化Trie)
    HDU 5416 CRB and Tree(前缀思想+DFS)
    HDU 3695 Computer Virus on Planet Pandora(AC自动机模版题)
    HDU 2222 Keywords Search(AC自动机模版题)
    POJ 2697 A Board Game(Trie判重+BFS)
    HDU 4287 Intelligent IME(字典树数组版)
    HDU 1160 FatMouse's Speed(要记录路径的二维LIS)
    HDU 1565&1569 方格取数系列(状压DP或者最大流)
  • 原文地址:https://www.cnblogs.com/DARKDD/p/3705824.html
Copyright © 2011-2022 走看看