Skip to content

Latest commit

 

History

History
41 lines (35 loc) · 3.35 KB

README.md

File metadata and controls

41 lines (35 loc) · 3.35 KB

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.