Advertisement
Guest User

Untitled

a guest
Aug 30th, 2015
60
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 3.23 KB | None | 0 0
  1. // "Copyright [2015] <Ricardo Sell>"
  2. template<typename T>
  3. class Lista {
  4. private:
  5.     int tamanholista;
  6.     int ultimo;
  7.     int valor;
  8.     T dados;
  9. public:
  10.     Lista() {  // construtor da classe lista
  11.         int posicao;  // variável para percorrer a lista
  12.         int valor;
  13.         int tamanholista = 100;
  14.         dados = new T[tamanholista];
  15.         ultimo = -1;
  16.     }
  17.     explicit Lista(int tam) {
  18.         ultimo = -1;
  19.         tamanholista = tam;
  20.         dados = new T[tamanholista];
  21.     }
  22.     void adiciona(T dado) {
  23.         if (listaCheia()) {
  24.             throw 1;
  25.         } else {
  26.             ultimo++;
  27.             dados[ultimo] = dado;
  28.         }
  29.     }
  30.     void adicionaNoInicio(T dado) {
  31.         if (listaCheia()) {
  32.             throw 1;
  33.         } else {
  34.             ultimo++;
  35.             posicao = ultimo;
  36.             while (posicao > 0) {
  37.                 dados[posicao] = dados[posicao - 1];
  38.             }
  39.             dados[0] = dado;
  40.         }
  41.     }
  42.     void adicionaNaPosicao(T dado, int destino) {
  43.         if (listaCheia()) {
  44.             throw 1;
  45.         } else {
  46.             if (destino > ultimo + 1 || destino < 0) {
  47.                 throw 1;
  48.             }
  49.             ultimo++;
  50.             posicao = ultimo;
  51.             while (posicao > destino) {
  52.                 dados[posicao] = dados[posicao - 1];
  53.                 posicao--;
  54.             }
  55.             dados[destino] = dado;
  56.         }
  57.     }
  58.     void adicionaEmOrdem(T dado) {
  59.         posicao = 0;
  60.         if (listaCheia()) {
  61.             throw 1;
  62.         } else {
  63.             while (posicao <= ulitmo && dado > (dados[posicao])) {
  64.                 posicao++;
  65.             }
  66.         }
  67.         return (adicionaNaPosicao(dado, posicao));
  68.     }
  69.     T retira() {
  70.         if (listaVazia()) {
  71.             throw 1;
  72.         } else {
  73.             ultimo--;
  74.         }
  75.         return dados[ultimo + 1];
  76.     }
  77.     T retiraDoInicio() {
  78.         if (listaVazia()) {
  79.             throw 1;
  80.         } else {
  81.             ultimo--;
  82.             valor = dados[0];
  83.             posicao = 0;
  84.             while (posicao <= ultimo) {
  85.                 dados[posicao] = dados[posicao + 1];
  86.                 posicao++;
  87.             }
  88.         }
  89.         return valor;
  90.     }
  91.     T retiraDaPosicao(int fonte) {
  92.         if (fonte > ultimo || fonte < 0) {
  93.             throw 1;
  94.         } else {
  95.             if (listaVazia()) {
  96.                 throw 1;
  97.             } else {
  98.                 ultimo--;
  99.                 valor = dados[fonte];
  100.                 posicao = fonte;
  101.                 while (posicao <= ultimo) {
  102.                     dados[posicao] = dados[posicao + 1];
  103.                     posicao++;
  104.                 }
  105.             }
  106.         }
  107.         return valor;
  108.     }
  109.     T retiraEspecifico(T dado) {
  110.         if (listaVazia()) {
  111.             throw 1;
  112.         } else {
  113.             posicao = posicao[dado];
  114.             if (posicao < 0) {
  115.                 throw 1;
  116.             }
  117.         }
  118.         return (retiraDaPosicao(posicao));
  119.     }
  120.     int posicao(T dado) {
  121.         ultimo = -1;
  122.         posicao = 0;
  123.         while (posicao <= ulitmo && !(igual(dado, dados[posicao] {
  124.                                     posicao++;
  125.                                 }
  126.                                 if (posicao > ultimo) {
  127.                                     throw 1;
  128.                                 }
  129.                                 return posicao;
  130.                             }
  131.                             bool contem(T dado) {
  132.                                 posicao = 0;
  133.                                 if (listaVazia()) {
  134.                                     throw 1;
  135.                                 } else {
  136.                                     while (posicao <= tamanholista) {
  137.                                         if (dados[posicao] != dado) {
  138.                                             posicao++;
  139.                                         } else {
  140.                                             break;
  141.                                         }
  142.                                     }
  143.                                 }
  144.                                 return dado;
  145.                             }
  146.                             bool igual(T dado1, T dado2) {
  147.                                 return (dado1 == dado2);
  148.                             }
  149.                             bool maior(T dado1, T dado2) {
  150.                                 return (dado1 > dado2);
  151.                             }
  152.                             bool menor(T dado1, T dado2) {
  153.                                 return dado1 < dado2;
  154.                             }
  155.                             bool listaCheia() {
  156.                                 return (ultimo == tamanholista - 1);
  157.                             }
  158.                             bool listaVazia() {
  159.                                 return (ultimo == -1);
  160.                             }
  161.                             void destroiLista() {
  162.                                 ultimo = -1;
  163.                             }
  164.                         };
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement