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

533 Comentários

  1. Thanks for sharing your info. I truly appreciate your efforts and I am waiting for your further write ups thanks once again.

    Here is my web site; borgata casino credit card – Abby

  2. Very nice post. I just stumbled upon your weblog and wished to say that I
    have really enjoyed surfing around your blog posts. After
    all I’ll be subscribing to your feed and I hope you write
    again soon!

    Here is my website :: blackjack dealer pay, Randy,

  3. best difference entre gambling and betting (Janna) websites uk,
    canada online casino no deposit and slot machine for sale
    uk, or how to deposit cash into paypal canada

  4. best new zealand casino, difference between european roulette and united kingdom casinos and statistics; Linnea, casino online australia free, or uk casino paypal

  5. online gambling legal in united states, auto poker dealer and best united kingdom
    online casinos real money, or top casino in united
    states for real money

    Feel free to surf to my web blog progression chart of roulette (Marylin)

  6. united states online casino games online tips (Elwood)
    real money, best slots online canada and australia casino online real
    money, or online casino with free signup bonus real money usa

  7. Thanks a bunch for sharing this with all of us you really realize what you are talking about!
    Bookmarked. Please additionally discuss with my site =).
    We can have a link trade arrangement among us

    Visit my web-site – homepage

Deixe um comentário

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