Skip to content

Primeira questão do trabalho final da disciplina de Programação III

Notifications You must be signed in to change notification settings

CarolFenixBr/lista-encadeada

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 

Repository files navigation

Programacao-III

Trabalho na disciplina de Programação III

QUESTÃO 1 de 2 – Lista Encadeada

Enunciado: Com a finalidade de melhorar o atendimento e priorizar os casos mais urgentes, a direção de um hospital criou um sistema de triagem em que um profissional da saúde classifica a ordem de atendimento com base numa avaliação prévia do paciente, entregando-lhe um cartão numerado verde (V) ou amarelo (A), que define o menor ou maior grau de urgência da ocorrência, respectivamente. Para informatizar esse processo, a direção do hospital contratou você para desenvolver uma fila de chamada seguindo as seguintes regras:

• Pacientes com cartão numerado amarelo (A) são chamados antes dos pacientes com cartão numerado verde (V) • Entre os pacientes com cartão numerado amarelo (A), os que tem numeração menor são atendidos antes. • Entre os pacientes com cartão numerado verde (V), os que tem numeração menor são atendidos antes. • As numerações dos cartões amarelos (A) iniciam em 201. • As numerações dos cartões verdes (V) inicial em 1.

Elabore um programa em Python que: A. Deve-se implementar uma Lista Encadeada Simples em que: [EXIGÊNCIA DE CÓDIGO 1 de 7]; a. O Nodo representa um cartão numerado contendo: número, cor e um ponteiro para o próximo; b. A lista contém um ponteiro para a cabeça da lista (head); B. Deve-se implementar a função inserirSemPrioridade(nodo) em que: [EXIGÊNCIA DE CÓDIGO 2 de 7]; a. Deve-se andar pela lista a partir da cabeça (head) e inserir o nodo no final da lista. C. Deve-se implementar a função inserirComPrioridade(nodo) em que: [EXIGÊNCIA DE CÓDIGO 3 de 7]; a. Deve-se andar pela lista a partir da cabeça (head) e inserir o nodo após todos os nodos com cor “A” que estão na lista. b. O nodo inserido deve sempre estar antes de todos os nodos com cor “V”. D. Deve-se implementar a função inserir() em que: [EXIGÊNCIA DE CÓDIGO 4 de 7]; a. Deve-se solicitar ao usuário a cor (“A” ou “V”) e o número (inteiro). b. Deve-se criar um nodo com a cor e o número fornecidos pelo usuário. c. Se a lista estiver vazia, a cabeça (head) da lista deve apontar para o nodo criado. d. Senão, se a cor do nodo for “V”, deve-se chamar a função inserirSemPrioridade(nodo). e. Senão, se a cor do nodo for “A”, deve-se chamar a função inserirComPriordade(nodo). E. Deve-se implementar a função imprimirListaEspera() em que: [EXIGÊNCIA DE CÓDIGO 5 de 7]; a. Deve-se imprimir todos os cartões e seus respectivos números a partir do primeiro até o último da lista. F. Deve-se implementar a função atenderPaciente() em que: [EXIGÊNCIA DE CÓDIGO 6 de 7]; a. Deve-se remover o primeiro paciente da fila e imprimir uma mensagem chamando o paciente para atendimento informando o número do seu cartão. G. Deve-se implementar um menu para utilização do sistema em que: [EXIGÊNCIA DE CÓDIGO 7 de 7]; a. Deve-se apresentar as opções (1 – adicionar paciente a fila, 2 – mostrar pacientes na fila, 3 – chamar paciente, 4 – sair) b. Se escolhida a opção 1, chamar a função inserir(). c. Se escolhida a opção 2, chamar a função imprimirListaEspera(). d. Se escolhida a opção 3, chamar a função atenderPaciente(). e. Se escolhida a opção 4, encerrar o programa. f. Se escolhida uma opção diferente as opções disponíveis, voltar ao item G.a.

About

Primeira questão do trabalho final da disciplina de Programação III

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages