Ir ao conteúdo

Lista encadeada, Estrutura de dados.

Saudações,

Para não perder o costume, irei postar outro exercicio resolvido em uma aula. Dessa vez o exercicio é o seguinte:
– Implemenetar o sistema de contabilidade de um mafioso. (outros detalhes continue lendo o post)

O enunciado do mesmo se encontra no “read the rest of this entry” para não deixar o post muito extenso devido ao longo enunciado.

A resolução do mesmo você pode baixar aqui.

Você é um Mafioso informatizado.
Você vai criar um sistema para gerenciar os seus débitos e também as pessoas que devem a você.
Este sistema será baseado em duas listas encadeadas:

(Imagem de exemplo)

* Para isso você vai fazer um programa que manipula mais de uma lista;

* o programa fará isto com um único conjunto de funções e passagem das diversas listas como parâmetros;
* como aplicação imaginemos um sistema de contabilidade simples;
* você vai ter um Plano de Contas constituído por duas listas: débitos e créditos;
* o mesmo conjunto de funções (que você já implementou) vai poder ser utilizado para isso: você somente precisa ampliar o conjunto de parâmetros da função para passar por referência também a lista que você quer alterar.

A passagem de parâmetro da lista deve ser por referência porque você deseja que as alterações sejam persistentes.

Cada lista de débitos ou créditos é constituída por lançamentos. Cada lançamento possui:

* um valor real (positivo);
* um nome. Por exemplo, “Pagar proteção à Mafia”

Estrutura:
tipo tLançamento {
caracter *nome;
real valor;
};

A lista encadeada que conterá os lançamentos terá um elemento de lista definido da seguinte forma:
Estrutura:
tipo tLista {
tLancamento* info;
tLista* proximo;
};
A cabeça de lista de cada lista será uma variável global contendo uma estrutura como abaixo:
tipo cLista {
tLista* lista;
inteiro ultimo;
};

No programa principal você vai definir se vai realizar uma operação de débito ou de crédito e vai chamar as operações sobre listas necessárias, passando a lista correta como parâmetro (por referência) para a função que realiza a operação.

Além das operações básicas que a lIsta vai oferecer, você deve implementar uma operação adicional: totalização. Essa operação funciona assim:

* percorre a lista, escrevendo o nome e o valor correspondente a cada item (débito ou crédito)
* soma o valor em uma variável auxiliar
* escreve ao final o total de débitos ou de créditos, dependendo de qual lista você mandou totalizar.

Publicado emAprendendoCEstrutura de Dados

2.465 Comentários

  1. Everything typed was actually very logical.
    But, what about this? what if you were to write a awesome headline?
    I am not suggesting your information is not solid., but what if
    you added something to maybe get people’s attention? I mean Linked List, Data Structure – Matheus
    Bratfisch is a little boring. You should peek at Yahoo’s home page
    and see how they create post titles to grab viewers to open the links.
    You might add a video or a pic or two to get
    people interested about what you’ve got to say. In my opinion, it might
    bring your website a little livelier.

    Also visit my website – Craps game java (goplayslots.net)

  2. Deb Deb

    best paying poker machines united states, gousaos quest
    free spins no deposit and best online games for
    real money in india (Deb) casino united kingdom
    fast payouts, or gambling in ontario united states

  3. poker united statesno gratis, best canadian no deposit casinos and legal gambling
    in united states, or online gambling websites usa

    Here is my web-site; baccarat hand mincer (Jorja)

  4. Asking questions are really good thing if you are not
    understanding something fully, except this paragraph
    presents pleasant understanding even.

    my webpage: homepage

  5. united kingdom casino no deposit bonus 2021, ainsworth poker machines australia and no deposit cash bonus casino canada, or are there pokies in western new zealand

    Feel free to surf to my blog post :: table limits blackjack vegas
    Claire

Deixe um comentário

O seu endereço de e-mail não será publicado. Campos obrigatórios são marcados com *