Esta tarefa consiste em receber um texto na entrada e contar quantos números primos existem nessa entrada. Porém, trata-se de um exercício de programação, e não somente de uma solução com algoritmo.
O objetivo desta tarefa é fazer o sistema operar como multi-processos,
usando a instrução fork()
.
As soluções deverão ser estruturadas de forma que:
- cada número deve ser analisado (quanto a ser primo ou não) por um processo independente.
- Os processo deverão (ao menos potencialmente) poder executar em paralelo.
- O programa deverá assumir um número máximo de processos paralelos igual a
4
. - Todos os processos devem encerrar antes do fim do programa principal
AVISO: os números serão inteiros, sem sinal, entre 0 e 2^(64)-1
Soluções que não contemplem esses três requisitos não serão aceitas. Eles serão verificados manualmente, caso a caso.
Entrada | Saida |
---|---|
0\n |
0\n |
1\n |
0\n |
2 1\n |
1\n (operando em dois processos) |
2 1 0\n |
1\n (operando em três processos) |
`3 5 2 7 9 1 0\n | 4\n (operando em quatro processos) |
- Vá diretamente ao conjunto de testes para verificar como tratar casos limítrofes ou mal-definidos.
- Lembre-se de seguir as instruções de submissão.
- Se desejar, proponha novos casos de teste.