Vamos a mais uma aula de dúvidas aqui no nosso Curso de Algoritmos e Lógica de Programação?
E a dúvida de hoje é: dada uma data de nascimento, como calcular a idade com dia mês e ano?
Já adianto que este não é um problema trivial. Para resolvê-lo precisamos, dentre outras coisas, descobrir se um ano é ou não bissexto.
Um ano é bissexto se:
– for múltiplo de 4;
– não for múltiplo de 100;
– for múltiplo de 400.
Com estas informações, podemos agora desenvolver uma função para verificar se um determinado ano é bissexto ou não, assim:
funcao inteiro bissexto(inteiro ano){
se(ano % 4 == 0 e ano % 100 != 0 ou ano % 400 == 0)
retorne 1
senao
retorne 0
}
Outra ação necessária é garantir que a data digita pelo usuário é uma data válida, correta. Isso é feito com a função a seguir:
funcao inteiro validarData(inteiro d, inteiro m, inteiro a){
se(d < 1 ou d > 31 ou m < 1 ou m > 12)
retorne 0
se(d == 31 e (m == 4 ou m == 6 ou m == 9 ou m == 11))
retorne 0
se(m == 2 e d > 29)
retorne 0
se(m == 2 e d == 29 e bissexto(a) == 0)
retorne 0
retorne 1
}
Também precisaremos saber a quantidade de dias de um mês para calcular não apenas os anos, mas também meses e dias. Para isso usaremos a função a seguir:
funcao inteiro diasNoMes(inteiro m, inteiro a){
se(m == 1 ou m == 3 ou m == 5 ou m == 7 ou m == 8 ou m == 10 ou m == 12)
retorne 31
senao{
se(m == 4 ou m == 6 ou m == 9 ou m == 11)
retorne 30
senao{
se(bissexto(a) == 1)
retorne 29
senao
retorne 28
}
}
}
Agora podemos então desenvolver um procedimento para calcular a idade do usuário. Como temos a data de nascimento, precisamos descobrir a data atual. Em uma abordagem simples, a data atual também poderia ser pedida ao usuário, mas aqui iremos obter diretamente do sistema por meio da biblioteca Calendario. Isso pode ser feito facilmente como apresentado a seguir:
da = Ca.dia_mes_atual() ma = Ca.mes_atual() aa = Ca.ano_atual()
Agora que temos as duas datas, podemos então calcular a diferença entre elas. A ideia utilizada nesta algoritmo é incrementar a data de nascimento até que ela se torne igual a data atual. Durante este processo contamos os anos, meses e dias.
funcao calcularIdade(inteiro dn, inteiro mn, inteiro an){
inteiro da, ma, aa, qtdDia = 0, qtdMes = 0, qtdAno = 0
da = Ca.dia_mes_atual()
ma = Ca.mes_atual()
aa = Ca.ano_atual()
enquanto(mn < ma - 1 ou an < aa){
mn++
qtdMes++
se(qtdMes == 12){
qtdMes = 0
qtdAno++
}
se(mn == 12){
an++
mn = 0
}
}
// ajustes para o último mes
se(dn == da){
qtdMes++
qtdDia = 0
}
senao se(dn < da){
qtdMes++
qtdDia = da - dn
}
senao{
qtdDia = diasNoMes(ma - 1, aa) + da - dn
}
escreva(qtdAno, " anos, ", qtdMes, " meses e ", qtdDia, " dias.\n")
}
Código completo em Portugol para calcular a idade do usuário
programa{
inclua biblioteca Calendario --> Ca
/*
* Código escrito por Wagner Gaspar
* Maior de 2021
*
* Função que verifica se um ano é bissexto
* RETORNO
* 1 - é bissexto
* 0 - não é bissexto
*
* -> Anos bissextos são múltiplos de 4,
* -> não múltiplos de 100 (1900 não é bissexto)
* -> e múltiplos de 400 (2000 é bissexto).
*
* EXEMPLOS DE ANOS BISSEXTOS:
* 1504 1508 1512 1516 1520 1524 1528 1532 1536 1540 1544 1548 1552 1556 1560 1564
* 1568 1572 1576 1580 1584 1588 1592 1596 1600 1604 1608 1612 1616 1620 1624 1628
* 1632 1636 1640 1644 1648 1652 1656 1660 1664 1668 1672 1676 1680 1684 1688 1692
* 1696 1704 1708 1712 1716 1720 1724 1728 1732 1736 1740 1744 1748 1752 1756 1760
* 1764 1768 1772 1776 1780 1784 1788 1792 1796 1804 1808 1812 1816 1820 1824 1828
* 1832 1836 1840 1844 1848 1852 1856 1860 1864 1868 1872 1876 1880 1884 1888 1892
* 1896 1904 1908 1912 1916 1920 1924 1928 1932 1936 1940 1944 1948 1952 1956 1960
* 1964 1968 1972 1976 1980 1984 1988 1992 1996 2000 2004 2008 2012 2016 2020 2024
*/
funcao inteiro bissexto(inteiro ano){
se(ano % 4 == 0 e ano % 100 != 0 ou ano % 400 == 0)
retorne 1
senao
retorne 0
}
/*
* Função que diz se uma determinada data é válida ou não
* RETORNO
* 1 - é válida
* 0 - não é válida
*/
funcao inteiro validarData(inteiro d, inteiro m, inteiro a){
se(d < 1 ou d > 31 ou m < 1 ou m > 12)
retorne 0
se(d == 31 e (m == 4 ou m == 6 ou m == 9 ou m == 11))
retorne 0
se(m == 2 e d > 29)
retorne 0
se(m == 2 e d == 29 e bissexto(a) == 0)
retorne 0
retorne 1
}
/*
* Função que retorna a quantidade de dias de um mês
* Recebe mês e ano
* 31 -> 1, 3, 5, 7, 8, 10, 12
* 30 -> 4, 6, 9, 11
* 28 ou 29 -> 2
*/
funcao inteiro diasNoMes(inteiro m, inteiro a){
se(m == 1 ou m == 3 ou m == 5 ou m == 7 ou m == 8 ou m == 10 ou m == 12)
retorne 31
senao{
se(m == 4 ou m == 6 ou m == 9 ou m == 11)
retorne 30
senao{
se(bissexto(a) == 1)
retorne 29
senao
retorne 28
}
}
}
/*
* Procedimento para calcular idade em anos, meses e dias
* Recebe como parâmetro a data de nascimento
* A data atual é obtida do sistema operacional
*/
funcao calcularIdade(inteiro dn, inteiro mn, inteiro an){
inteiro da, ma, aa, qtdDia = 0, qtdMes = 0, qtdAno = 0
da = Ca.dia_mes_atual()
ma = Ca.mes_atual()
aa = Ca.ano_atual()
enquanto(mn < ma - 1 ou an < aa){
mn++
qtdMes++
se(qtdMes == 12){
qtdMes = 0
qtdAno++
}
se(mn == 12){
an++
mn = 0
}
}
// ajustes para o último mes
se(dn == da){
qtdMes++
qtdDia = 0
}
senao se(dn < da){
qtdMes++
qtdDia = da - dn
}
senao{
qtdDia = diasNoMes(ma - 1, aa) + da - dn
}
escreva(qtdAno, " anos, ", qtdMes, " meses e ", qtdDia, " dias.\n")
}
funcao inicio(){
inteiro d, m, a
escreva("Digite sua data de nascimento no formato dd mm aaaa: ")
leia(d, m, a)
se(validarData(d, m, a) == 1){
calcularIdade(d, m, a)
}
senao
escreva("Dada inválida!\n")
}
}

Por favor, teste sua função colocando a data de nascimento 31/01/2023 e data atual 01/04/2023, resultará um mês e menos dois dias.
Positivo.