Advertisement
Guest User

Untitled

a guest
May 20th, 2019
69
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 2.23 KB | None | 0 0
  1. #include "le.h"
  2. #include <stdlib.h>
  3.  
  4. struct llist * create_l(){
  5.     struct llist * ptr;
  6.  
  7.     ptr = malloc(sizeof(struct llist));
  8.     ptr->cabeca = NULL;
  9.     ptr->tam = 0;
  10.  
  11.     return ptr;
  12. }
  13.  
  14. elem * create_node(int val){
  15.  
  16.     elem * ptr;
  17.  
  18.     ptr = malloc(sizeof(elem));
  19.  
  20.     ptr->val = val;
  21.     ptr->next = NULL;
  22.  
  23.     return ptr;
  24.  
  25. }
  26.  
  27. int insert_l(struct llist * desc, elem * prev, elem * item){
  28.    
  29.     //Adição no ínicio
  30.     if(prev == NULL){
  31.         if(desc->cabeca == NULL){
  32.             desc->cabeca = item;
  33.             desc->tam++;
  34.             return 1;
  35.         }
  36.  
  37.         item->next = desc->cabeca;
  38.  
  39.         desc->cabeca = item;
  40.         desc->tam++;
  41.         return 1;
  42.     }
  43.  
  44.     item->next = prev->next;
  45.     prev->next = item;
  46.  
  47.     desc->tam++;
  48.  
  49.     return 1;
  50. }
  51.  
  52. int delete_l(struct llist * desc, elem * prev){
  53.  
  54.     elem * temp;
  55.  
  56.     if(prev == NULL){
  57.         temp = desc->cabeca;
  58.         desc->cabeca = temp->next;
  59.         desc->tam--;
  60.         free(temp);
  61.  
  62.         return 1;
  63.     }
  64.  
  65.     temp = prev->next;
  66.     prev->next = temp->next;
  67.     desc->tam--;
  68.     free(temp);
  69.  
  70.     return 1;
  71.  
  72. }
  73.  
  74. elem * get_l(struct llist * desc, int pos){
  75.  
  76.     int i;
  77.     elem *ptr;
  78.  
  79.     if(pos > desc->tam || pos < 1)
  80.         return NULL;
  81.  
  82.     if(pos == 1)
  83.         return desc->cabeca;
  84.  
  85.     ptr = desc->cabeca;
  86.  
  87.     for(i = 0; i < pos; i++){
  88.         ptr = ptr->next;
  89.     }
  90.  
  91.     return ptr;
  92. }
  93.  
  94. int set_l(struct llist * desc, int pos, int val){
  95.  
  96.     elem *ptr;
  97.  
  98.     ptr = get_l(desc, pos);
  99.  
  100.     if(ptr == NULL)
  101.         return 0;
  102.  
  103.     ptr->val = val;
  104.  
  105.     return 1;
  106.  
  107. }
  108.  
  109. elem * locate_l(struct llist * desc, elem * prev, int val){
  110.  
  111.     elem *ptr;
  112.  
  113.     if(prev == NULL)
  114.         ptr = desc->cabeca;
  115.  
  116.     else
  117.         ptr = prev;
  118.    
  119.  
  120.     while(ptr != NULL){
  121.         if(ptr->val == val)
  122.             return ptr;
  123.  
  124.         ptr = ptr->next;
  125.     }
  126.  
  127.     return NULL;
  128. }
  129.  
  130. int length_l(struct llist * desc){
  131.     return desc->tam;
  132. }
  133.  
  134. void destroy_l(struct llist * desc){
  135.    
  136.     int i;
  137.    
  138.     if(desc->cabeca == NULL)
  139.         free(desc);
  140.  
  141.     else {
  142.  
  143.         for(i = 0; i < desc->tam; i++){
  144.             delete_l(desc, NULL);
  145.         }
  146.  
  147.         free(desc);
  148.     }
  149. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement