1. Escreve um programa em Pascal para ler, calcular e escrever a média aritmética
entre dois números.
program ex1;
program ex1;
uses crt;
var n1, n2, m: real;
begin
clrscr;
write('Informe um numero: ');
readln(n1);
write('Informe outro numero: ');
readln(n2);
m:=(n1+n2)/2;
writeln('A media ‚: ',m:0:2);
readkey;
end.
2. Escreve um programa em Pascal para ler um número positivo qualquer, calcular e escrever o quadrado e a raiz quadrada do mesmo.
program ex2;
uses crt;
var x, q: integer;
r: real;
begin
clrscr;
write('Informe um numero: ');
readln(x);
q:= sqr(x);
writeln('O quadrado de ', x, ' ‚ ', q);
if x>=0 then
begin
r:= sqrt(x);
writeln('A raiz quadrada de ', x, ' ‚ ', r:0:2);
end
else
begin
writeln('Nao existe raiz de ',x);
end;
readkey;
end.
3. Escreve um programa em Pascal que leia 3 valores: a, b, c e calcule e escreva a média aritmética, harmônica e geométrica correspondente.
program ex3;
uses crt;
var a, b, c, ma, mg, mh: real;
begin
clrscr;
write('Informe o primeiro numero: ');
readln(a);
write('Informe o segundo numero: ');
readln(b);
write('Informe o terceiro numero: ');
readln(c);
ma:= (a+b+c)/3;
mh:= 3/(1/a + 1/b +1/c);
mg:= exp(ln(a*b*c)*(1/3));
writeln('Media Aritmetica: ',ma:0:2);
writeln('Media Harmonica: ',mh:0:2);
writeln('Media Geometrica: ',mg:0:2);
readkey;
end.
4. Escreve um programa em Pascal que lê o número de um funcionário, seu número de horas trabalhadas, o valor que recebe por hora, e o número de filhos com idade menor do que 14 anos e calcula o salário deste funcionário.
program ex4;
uses crt;
var
nf, nfil: integer;
nht, vph, sf, st: real;
begin
clrscr;
write('Informe o numero do funcionario: ');
readln(nf);
write('Informe o numero de horas trabalhadas: ');
readln(nht);
write('Informe o valor que recebe por hora: ');
readln(vph);
write('Informe o numero de filhos: ');
readln(nfil);
write('Informe o valor do salario familia: ');
readln(sf);
st:= nht * vph + nfil * sf;
writeln('O funcionario ', nf, ' recebe um salario total de R$ ', st:0:2);
readkey;
end.
5. Escreve um programa em Pascal que lê o número de um vendedor, o seu salário-fixo, o tota1 de vendas por ele efetuadas e o percentual que ganha sobre o total de vendas. Calcular o salário tota1 do vendedor. Escrever número do vendedor e o salário total.
program ex5;
uses crt;
var
nv: integer;
sf, tv, per, st: real;
begin
clrscr;
write('Informe o numero do vendedor: ');
readln(nv);
write('Informe o salario fixo: ');
readln(sf);
write('Informe o total de vendas: ');
readln(tv);
write('Informe o percentual sobre as vendas: ');
readln(per);
st:= sf + tv * per / 100;
writeln('O vendedor ', nv, ' recebe um salario total de R$ ', st:0:2);
readkey;
end.
6. Escreve um programa em Pascal que lê 3 valores a, b, c que são lados de um triângulo e calcule a área deste triângulo.
program ex6;
uses crt;
var a, b, c, s, at: real;
begin
clrscr;
write('Informe o primeiro numero: ');
readln(a);
write('Informe o segundo numero: ');
readln(b);
write('Informe o terceiro numero: ');
readln(c);
s:= (a+b+c)/2;
at:=sqrt(s*(s-a)*(s-b)*(s-c));
writeln('Area do triangulo: ',at:0:2);
readkey;
end.
7. Uma revendedora de carros usados paga aos funcionários vendedores um salário fixo por mês, mais uma comissão também fixa para cada carro vendido e mais 5% do valor das vendas por ele efetuadas.
Escreve um programa em Pascal que lê o número do vendedor, o número de carros por ele vendidos, o valor tota1 de suas vendas, o salário fixo e o valor que recebe por carro vendido e calcula o salário mensal do vendedor, escrevendo-o juntamente com o seu número de identificação.
Escreve um programa em Pascal que lê o número do vendedor, o número de carros por ele vendidos, o valor tota1 de suas vendas, o salário fixo e o valor que recebe por carro vendido e calcula o salário mensal do vendedor, escrevendo-o juntamente com o seu número de identificação.
program ex7;
uses crt;
var
nv, ncv: integer;
sf, tv, vpcv, st: real;
begin
clrscr;
write('Informe o numero do vendedor: ');
readln(nv);
write('Informe o numero de carros vendidos: ');
readln(ncv);
write('Informe o total de vendas: ');
readln(tv);
write('Informe o salario fixo: ');
readln(sf);
write('Informe o valor por carro vendido: ');
readln(vpcv);
st:= sf + tv * 5 / 100 + ncv * vpcv;
writeln('O vendedor ', nv, ' recebe um salario total de R$ ', st:0:2);
readkey;
end.
8. Escreve um programa em Pascal que lê 3 valores a, b, c, e escreva os 3 valores em ordem crescente.
program ex8;
uses crt;
var a, b, c, aux: integer;
begin
clrscr;
write('Informe o primeiro numero: ');
readln(a);
write('Informe o segundo numero: ');
readln(b);
write('Informe o terceiro numero: ');
readln(c);
if a>b then
begin
aux:=a;
a:=b;
b:=aux;
end;
if a>c then
begin
aux:=a;
a:=c;
c:=aux;
end;
if b>c then
begin
aux:=b;
b:=c;
c:=aux;
end;
writeln('Valores em ordem crescente: ', a:6, b:6, c:6);
readkey;
end.
9. Escreve um algoritmo/programa em Pascal que lê um conjunto de 4 valores i, a, b, c, onde i é um valor inteiro e positivo e a, b, c, são quaisquer valores reais e os escreva. A seguir:
Se i = 1 escrever os 3 valores a, b, c em ordem crescente.
Se i = 2 escrever os 3 valores a, b, c em ordem decrescente.
Se i = 3 escrever os 3 valores de forma que o maior valor entre a, b, c fica entre os outros 2.
program ex9;
uses crt;
var i, a, b, c, aux: integer;
begin
clrscr;
write('Informe um valor [1, 2, 3]: ');
readln(i);
write('Informe o primeiro numero: ');
readln(a);
write('Informe o segundo numero: ');
readln(b);
write('Informe o terceiro numero: ');
readln(c);
if a>b then
begin
aux:=a;
a:=b;
b:=aux;
end;
if a>c then
begin
aux:=a;
a:=c;
c:=aux;
end;
if b>c then
begin
aux:=b;
b:=c;
c:=aux;
end;
if i=1 then
begin
writeln('Valores em ordem crescente: ', a:6, b:6, c:6);
end;
if i=2 then
begin
writeln('Valores em ordem decrescente: ', c:6, b:6, a:6);
end;
if i=3 then
begin
writeln('Maior Valor no meio: ', a:6, c:6, b:6);
end;
readkey;
end.
10. Escreve um algoritmo/programa em Pascal que lê o número de um vendedor de uma empresa, seu salário fixo e o total de vendas por ele efetuadas.
Cada vendedor recebe um salário fixo, mais uma comissão proporcional às vendas por ele efetuadas.
A comissão é de 3% sobre o total de vendas até $ 1.000,00 e 5% sobre o que ultrapassa este valor.
Escreve o número do vendedor, o total de suas vendas, seu salário fixo e seu salário total.
program ex10;
uses crt;
var
nv: integer;
sf, tv st: real;
begin
clrscr;
write('Informe o numero do vendedor: ');
readln(nv);
write('Informe o total de vendas: ');
readln(tv);
write('Informe o salario fixo: ');
readln(sf);
if tv<=1000 then
begin
st:= sf + tv * 3 / 100;
end
else
begin
st:= sf + (tv-1000) * 5 / 100 + 30;
end;
writeln('O vendedor ', nv, ' recebe um salario total de R$ ', st:0:2);
readkey;
end.
51. Escrever um a1goritmo que lê um vetor A[15] e o escreve. Ordene, a seguir os elementos de A em ordem crescente e escreva novamente A.
11. Escreve um algoritmo/programa em Pascal que lê 3 comprimentos de lados a, b, c e os ordena em ordem decrescente, de modo que o a represente o maior dos 3 lados lidos.
Determine, a seguir, o tipo de triângulo que estes 3 lados formam, com base nos seguintes casos escrevendo sempre os valores lidos e uma mensagem adequada:
Se a > b + c não formam triângulo algum.
Se a2 = b2 + c2 formam um triângulo retângulo.
Se a2 > b2 + c2 formam um triângulo obtusângulo.
Se a2 < b2 + c2 formam um triângulo acutângulo.
Se forem todos iguais formam um triângulo equilátero.
Se a = b ou b = c ou a = c então formam um triângulo isósceles
program ex11;
uses crt;
var a, b, c, aux: integer;
begin
clrscr;
write('Informe o primeiro numero: ');
readln(a);
write('Informe o segundo numero: ');
readln(b);
write('Informe o terceiro numero: ');
readln(c);
if a<b then
begin
aux:=a;
a:=b;
b:=aux;
end;
if a<c then
begin
aux:=a;
a:=c;
c:=aux;
end;
if b<c then
begin
aux:=b;
b:=c;
c:=aux;
end;
if a>b+c then
begin
writeln('Nao forma triangulo.');
end
else
begin
if sqr(a) = sqr(b)+sqr(c) then writeln('Formam um triangulo retangulo.');
if sqr(a) > sqr(b)+sqr(c) then writeln('Formam um triangulo obtusangulo.');
if sqr(a) < sqr(b)+sqr(c) then writeln('Formam um triangulo acutangulo.');
if (a=b) and (b=c) then
begin
writeln('Formam um triangulo equilatero.');
end
else
begin
if (a=b) or (a=c) or (b=c) then writeln('Formam um triangulo isosceles.');
end;
end;
readkey;
end.
12. Escrever um algoritmo/programa em Pascal que lê a hora de início de um jogo e a hora do final do jogo (considerando apenas horas inteiras) e calcula a duração do jogo em horas, sabendo-se que o tempo máximo de duração do jogo é de 24 horas e que o jogo pode iniciar em um dia e terminar no dia seguinte.
program ex12;
uses crt;
var
hi, hf, dj: integer;
begin
clrscr;
write('Informe a hora inicial do jogo: ');
readln(hi);
write('Informe a hora final do jogo: ');
readln(hf);
if hf > hi then
begin
dj:=hf - hi;
writeln('O jogo durou ',dj,' horas.');
end
else
begin
dj:=hf - hi + 24;
writeln('O jogo durou ',dj,' horas.');
end;
readkey;
end.
15. A empresa Enxuga Gelo SA decidiu conceder um aumento de salários a seus funcionários de acordo com a tabela abaixo:
Salário Atual Índice De Aumento
0 - 400,00 15%
400,01 - 700,00 12%
700,01 - 1.000,00 10%
1.000,01 - 1.800,00 7%
1.800,01 - 2.500,00 4%
acima de 2.500,00 sem aumento
Escrever um algoritmo/programa em Pascal que lê, para cada funcionário, o seu número e o seu salário atual e escreve o numero do funcionário, seu salário atua1, o percentual de seu aumento e o valor do salário corrigido.
program ex15;
uses crt;
var
nf: integer;
pa, sc, sa: real;
begin
clrscr;
write('Informe o numero do funcionario: ');
readln(nf);
write('Informe o salario atual: ');
readln(sa);
if sa<=400 then pa:=15;
if (sa>400) and (sa<=700) then pa:=12;
if (sa>700) and (sa<=1000) then pa:=10;
if (sa>1000) and (sa<=1800) then pa:=7;
if (sa>1800) and (sa<=2500) then pa:=4;
if (sa>2500) then pa:=0;
sc:=sa + sa * pa/100;
writeln('Funcionario: ', nf);
writeln('Salario Atual: ',sa:0:2);
writeln('Percentual de Aumento: ',pa:0:2,'%');
writeln('Salario Corrigido: ',sc:0:2);
readkey;
end.
end.
17. Escrever um algoritmo/programa em Pascal que lê 5 valores para a, um de cada vez, e conta quantos destes valores são negativos, escrevendo esta informação.
program ex17;
uses crt;
var i, a, cont: integer;
begin
clrscr;
cont:=0;
for i:= 1 to 5 do
begin
write('Informe um valor: ');
readln(a);
if a<0 then cont:=cont+1;
end;
writeln('Existem ',cont,' valores negativos.');
readkey;
end.
18. Escrever um algoritmo/programa em Pascal que escreve os números pares entre 100 e 200.
program ex18;
uses crt;
var i: integer;
begin
clrscr;
writeln('Os numeros pares de 100 a 200 sao: ');
for i:= 100 to 200 do
begin
if i mod 2 = 0 then
begin
write(i:8);
end;
end;
readkey;
end.
19. Escrever um algoritmo/programa em Pascal que escreve a soma dos números entre 0 e 100.
program ex19;
uses crt;
var i, soma: integer;
begin
clrscr;
soma:=0;
for i:= 0 to 100 do
begin
soma:= soma + i;
end;
writeln('A soma dos numeros de 0 a 100 e: ', soma);
readkey;
end.
20. Escrever um algoritmo/programa em Pascal que escreve a soma dos números pares entre 0 e 100.
program ex20;
uses crt;
var i, soma: integer;
begin
clrscr;
soma:=0;
for i:= 0 to 100 do
begin
if i mod 2 = 0 then
begin
soma:= soma + i;
end;
end;
writeln('A soma dos numeros pares de 0 a 100 e: ', soma);
readkey;
end.
21. Escrever um algoritmo/programa em Pascal que escreve a soma dos números múltiplos de 7 entre 100 e 200.
program ex21;
uses crt;
var i, soma: integer;
begin
clrscr;
soma:=0;
for i:= 100 to 200 do
begin
if i mod 7 = 0 then
begin
soma:= soma + i;
end;
end;
writeln('A soma dos numeros multiplos de 7 de 100 a 200 e: ', soma);
readkey;
end.
22. Escrever um algoritmo/programa em Pascal que escreve a soma dos números que não são múltiplos de 13 entre 100 e 200.
program ex22;
uses crt;
var i, soma: integer;
begin
clrscr;
soma:=0;
for i:= 100 to 200 do
begin
if i mod 13 <> 0 then
begin
soma:= soma + i;
end;
end;
writeln('A soma dos numeros nao multiplos de 13 de 100 a 200 e: ', soma);
readkey;
end.
23. Escrever um algoritmo/programa em Pascal que lê 20 valores, um de cada vez, e conta quantos deles estão em cada um dos intervalos [0, 25], (25, 50], (50, 75], (75, 100], escrevendo esta informação
program ex23;
uses crt;
var i, x, cont1, cont2, cont3, cont4: integer;
begin
clrscr;
cont1:=0; cont2:=0; cont3:=0; cont4:=0;
for i:= 1 to 20 do
begin
write('Informe um valor (0-100): ');
readln(x);
if (x>=0) and (x<=25) then cont1:=cont1 + 1;
if (x>25) and (x<=50) then cont2:=cont2 + 1;
if (x>50) and (x<=75) then cont3:=cont3 + 1;
if (x>75) and (x<=100) then cont4:=cont4 + 1;
end;
writeln('No intervalo 0 - 25 existem ', cont1, ' numeros.');
writeln('No intervalo 26 - 50 existem ', cont2, ' numeros.');
writeln('No intervalo 51 - 75 existem ', cont3, ' numeros.');
writeln('No intervalo 76 - 100 existem ', cont4, ' numeros.');
readkey;
end.
24. Escrever um algoritmo/programa em Pascal semelhante ao anterior que calcula as médias aritméticas de cada intervalo e as escreve, juntamente com o número de valores de cada intervalo.
program ex24;
uses crt;
var
i, x, cont1, cont2, cont3, cont4, soma1, soma2, soma3, soma4: integer;
m1, m2, m3, m4: real;
begin
clrscr;
cont1:=0; cont2:=0; cont3:=0; cont4:=0;
soma1:=0; soma2:=0; soma3:=0; soma4:=0;
for i:= 1 to 20 do
begin
write('Informe um valor (0-100): ');
readln(x);
if (x>=0) and (x<=25) then
begin
cont1:=cont1 + 1;
soma1:=soma1 + x;
m1:=soma1 / cont1;
end;
if (x>25) and (x<=50) then
begin
cont2:=cont2 + 1;
soma2:=soma2 + x;
m2:=soma2 / cont2;
end;
if (x>50) and (x<=75) then
begin
cont3:=cont3 + 1;
soma3:=soma3 + x;
m3:=soma3 / cont3;
end;
if (x>75) and (x<=100) then
begin
cont4:=cont4 + 1;
soma4:=soma4 + x;
m4:=soma4 / cont4;
end;
end;
writeln('No intervalo 0 - 25 existem ', cont1, ' numeros e a media e: ', m1:0:2);
writeln('No intervalo 26 - 50 existem ', cont2, ' numeros e a media e: ', m2:0:2);
writeln('No intervalo 51 - 75 existem ', cont3, ' numeros e a media e: ', m3:0:2);
writeln('No intervalo 76 - 100 existem ', cont4, ' numeros e a media e: ', m4:0:2);
readkey;
end.
25. Escrever um algoritmo/programa em Pascal que lê um número e calcula e escreve quantos divisores ele possui.
program ex25;
uses crt;
var x, i, cont: integer;
begin
clrscr;
write('Informe um numero: ');
readln(x);
cont:=0;
for i:= 1 to x do
begin
if x mod i = 0 then cont:=cont + 1;
end;
writeln('O numero ', x, ' possui ', cont, ' divisores.');
readkey;
end.
26. Escrever um algoritmo/programa em Pascal que lê um número e calcula e escreve o seu fatorial.
program ex26;
uses crt;
var x, i: integer;
fat: longint;
begin
clrscr;
write('Informe um numero: ');
readln(x);
fat:=1;
for i:= 1 to x do
begin
fat:=fat * i;
end;
writeln('O fatorial de ', x, ' e: ', fat);
readkey;
end.
27. Escrever um algoritmo/programa em Pascal que lê um número e escreva se ele "é primo" ou "não é primo"
program ex27;
uses crt;
var x, i, cont: integer;
begin
clrscr;
write('Informe um numero: ');
readln(x);
cont:=0;
for i:= 1 to x do
begin
if x mod i = 0 then cont:=cont + 1;
end;
if cont<=2 then
begin
writeln('O numero ', x, ' e primo.');
end
else
begin
writeln('O numero ', x, ' nao e primo.');
end;
readkey;
end.
28. Escrever um algoritmo/programa em Pascal que escreve os números múltiplos de 7 entre 100 e 200, bem como a soma destes números.
program ex28;
uses crt;
var i, soma: integer;
begin
clrscr;
soma:=0;
writeln('Os numeros multiplos de 7 de 100 a 200 sao:');
for i:= 100 to 200 do
begin
if i mod 7 = 0 then
begin
write(i:8);
soma:= soma + i;
end;
end;
writeln;
writeln;
writeln('A soma dos numeros multiplos de 7 de 100 a 200 e: ', soma);
readkey;
end.
29. Escrever um algoritmo/programa em Pascal que lê um número não conhecido de valores, um de cada vez, e conta quantos deles estão em cada um dos intervalos [0, 50], (50, 100], (100,200]. O programa deve encerrar quando for informado um valor fora dos intervalos.
Questão do Trabalho.
30. Escrever um algoritmo/programa em Pascal que lê um número não determinado de valores para m, todos inteiros e positivos, um de cada vez. Se m for par, verificar quantos divisores possui e escrever esta informação. Se m for ímpar e menor do que 12 calcular e escrever o fatorial de m. Se m for ímpar e maior ou igua1 a 12 calcular e escrever a soma dos inteiros de l até m.
Questão do Trabalho.
31. Escrever um algoritmo/programa em Pascal que lê um número não determinados de valores a, todos inteiros e positivos, um de cada vez, e calcule e escreva a média aritmética dos valores lidos, a quantidade de valores pares, a quantidade de valores impares, a percentagem de valores pares e a percentagem de valores ímpares.
Questão do Trabalho.
32. Escrever um algoritmo/programa em Pascal que escreve os números primos entre 100 e 200, bem como a soma destes números.
program ex32;
uses crt;
var x, i, cont: integer;
begin
clrscr;
for x:= 100 to 200 do
begin
cont:=0;
for i:= 1 to x do
begin
if x mod i = 0 then cont:=cont + 1;
end;
if cont<=2 then
begin
writeln('O numero ', x, ' e primo.');
end;
end;
readkey;
end.
33. Escrever um algoritmo/programa em Pascal que lê 5 conjuntos de 4 valores a, b, c, d, um conjunto por vez e os escreve assim como foram lidos. Em seguida, ordene-os em ordem decrescente e escreva-os novamente.
program ex33;
uses crt;
var i, a, b, c, d, aux: integer;
begin
clrscr;
for i:= 1 to 5 do
begin
write('Informe um valor: ');
readln(a);
write('Informe um valor: ');
readln(b);
write('Informe um valor: ');
readln(c);
write('Informe um valor: ');
readln(d);
writeln('Numeros digitados: ', a:6, b:6, c:6, d:6);
if a<b then
begin
aux := a;
a := b;
b := aux;
end;
if a<c then
begin
aux := a;
a := c;
c := aux;
end;
if a<d then
begin
aux := a;
a := d;
d := aux;
end;
if b<c then
begin
aux := b;
b := c;
c := aux;
end;
if b<d then
begin
aux := b;
b := d;
d := aux;
end;
if c<d then
begin
aux := c;
c := d;
d := aux;
end;
writeln('Em ordem decrescente: ', a:6, b:6, c:6, d:6);
readkey;
end;
end.
34. Escrever um algoritmo/programa em Pascal que lê 10 valores para n, um de cada vez, todos inteiros e positivos, e para cada n lido, escreva a tabuada de 1 até n de n.
program ex34;
uses crt;
var i, j, n: integer;
begin
clrscr;
for i:= 1 to 10 do
begin
write('Informe um n£mero: ');
readln(n);
for j:= 1 to n do
begin
writeln(j, ' x ', n, ' = ', j * n);
end;
end;
readkey;
end.
35. Escrever um algoritmo/programa em Pascal que lê 5 pares de valores a, b, todos inteiros e positivos, um par de cada vez, e com a < b, e escreve os inteiros pares de a até b, incluindo o a e b se forem pares.
program ex35;
uses crt;
var i, j, a, b, aux: integer;
begin
clrscr;
for i:= 1 to 5 do
begin
write('Informe um n£mero: ');
readln(a);
write('Informe um n£mero: ');
readln(b);
if a>b then
begin
aux:=a;
a:=b;
b:=aux;
end;
for j:= a to b do
begin
if j mod 2 = 0 then writeln(j);
end;
end;
readkey;
end.
36. A série de Fibonacci tem como dados os 2 primeiros termos da série que são respectivamente 0 e 1. A partir deles, os demais termos são construídos pela seguinte regra: tn = tn-1 + tn-2. Escrever um algoritmo/programa em Pascal que gera os 10 primeiros termos da Série de Fibonacci e calcula e escreve a soma destes termos.
program ex36;
uses crt;
var ult, pen, nt, i: integer;
begin
clrscr;
writeln('Termos Serie Fibonacci:');
pen:=0;
ult:=1;
writeln(pen);
writeln(ult);
for i:= 1 to 8 do
begin
nt:=ult + pen;
writeln(nt);
pen:=ult;
ult:=nt;
end;
readkey;
end.
39. Escrever um algoritmo/programa em Pascal que lê 5 conjuntos de 2 valores, o primeiro representando o número de um aluno e o segundo representando a sua altura em centímetros. Encontrar o aluno mais alto e o mais baixo e escrever seus números, suas alturas e uma mensagem dizendo se é o mais alto ou o mais baixo.
Questão do Trabalho.
40. Escrever um algoritmo/programa em Pascal que gera e escreve os 5 primeiros números perfeitos. Um número perfeito é aquele que é igual a soma dos seus divisores. (Ex.: 6 = l + 2 + 3; 28 = 1 + 2 + 4 + 7 + 14 etc.).
program ex40;
uses crt;
var cont, x, soma, i: integer;
begin
clrscr;
cont:=0;
x:=0;
writeln('Os numeros perfeitos sao: ');
repeat
x:=x+1;
soma:=0;
for i:= 1 to x-1 do
begin
if x mod i = 0 then soma:=soma + i;
end;
if soma = x then
begin
writeln(x);
cont:=cont+1;
end
until cont=4;
writeln('Pressione qualquer tecla para finalizar...');
readkey;
end.
41. Escrever um algoritmo/programa em Pascal que lê 50 valores, um de cada vez, e encontra e escreve o maior deles.
program ex41;
uses crt;
var i, x, m: integer;
begin
clrscr;
for i:= 1 to 50 do
begin
write('Informe o ',i,'.o valor: ');
readln(x);
if i=1 then
begin
m:=x;
end;
if x > m then
begin
m:=x;
end;
end;
writeln('O maior valor e: ', m);
readkey;
end.
42. Escrever um algoritmo/programa em Pascal que gera os números de 1000 a 1999 e escreve aqueles que divididos por 11 dão um resto igual a 5.
program ex42;
uses crt;
var
i: integer;
begin
clrscr;
for i:= 1000 to 1999 do
begin
if i mod 11 = 5 then write(i:8);
end;
readkey;
end.
43. Escrever um algoritmo/programa em Pascal que lê um valor N e calcula e escreve os 20 primeiros termos da série: 1 + 1/x2 + 1/x3 + 1/x4 + ...
program ex43;
uses crt;
var
x, i: integer;
t, soma: real;
begin
clrscr;
soma:=0;
write('Informe um valor: ');
readln(x);
writeln('Termos:');
t:=1;
writeln(t:0:8);
soma:=soma+t;
for i:= 2 to 20 do
begin
t:= 1/ (exp(ln(x)*i));
writeln(t:0:8);
soma:=soma+t;
end;
writeln('A soma e: ', soma:0:8);
readkey;
end.
44. Escrever um algoritmo/programa em Pascal que calcula e escreve o produto dos números primos entre 92 e 1478.
Questão do Trabalho.
45. Escrever um algoritmo/programa em Pascal que lê N, inteiro e positivo e calcula e escreve o termo de ordem N da sucessão abaixo: ordem: 1 2 3 4 5 6 7 8 ... sucessão: -1 0 5 6 11 12 17 18 ...
program ex45;
uses crt;
var x, i, nro: integer;
begin
clrscr;
write('Informe um numero: ');
readln(x);
nro:=-1;
for i:= 1 to x do
begin
write(nro:4);
if i mod 2 <> 0 then
begin
nro:=nro+1;
end
else
begin
nro:=nro+5;
end;
end;
readkey;
end.
47.Escrever um algoritmo/programa em Pascal que lê um vetor V[6] e o escreve. Conte, a seguir quantos valores de V são negativos e escreva esta informação.
program ex47;
uses crt;
var v: array[1..6] of integer;
i, cont: integer;
begin
clrscr;
for i:= 1 to 6 do
begin
writeln('Informe o ', i ,'§ valor: ');
readln(v[i]);
end;
for i:= 1 to 6 do
begin
writeln(v[i]);
end;
cont:=0;
for i:= 1 to 6 do
begin
if v[i]<0 then
begin
cont:=cont+1;
end;
end;
writeln('Existem ',cont,' valores negativos.');
readkey;
end.
48. Escrever um algoritmo/programa em Pascal que lê um vetor X(100) e o escreve. Substitua, a seguir, todos os valores nulos de X por 1 e escreva novamente o vetor x
program ex48;
uses crt;
var
x: array[1..100] of integer;
i: integer;
begin
clrscr;
for i:= 1 to 100 do
begin
writeln('Informe o ', i ,'§ valor: ');
readln(x[i]);
end;
for i:= 1 to 100 do
begin
writeln(x[i]);
end;
for i:= 1 to 100 do
begin
if x[i]=0 then
begin
x[i]:=1;
end;
end;
for i:= 1 to 100 do
begin
writeln(x[i]);
end;
readkey;
end.
49. Escrever um algoritmo/programa em Pascal que lê um vetor C[50] e o escreve. Encontre, a seguir, o maior elemento de C e o escreva.
program ex49;
uses crt;
var
c: array[1..50] of integer;
m, i: integer;
begin
clrscr;
for i:= 1 to 50 do
begin
writeln('Informe o ', i ,'§ valor: ');
readln(c[i]);
end;
for i:= 1 to 50 do
begin
writeln(c[i]);
end;
m:=c[1];
for i:= 1 to 50 do
begin
if c[i]>m then
begin
m:=c[i];
end;
end;
writeln('O maior valor e: ', m);
readkey;
end.
50. Escrever um algoritmo/programa em Pascal que lê um vetor N[80] e o escreve. Encontre, a seguir, o menor elemento e a sua posição no vetor N e escreva: "o menor elemento de n é = ", M, "e a sua posição é = ", P.
program ex50;
uses crt;
var
n: array[1..80] of integer;
m, p, i: integer;
begin
clrscr;
for i:= 1 to 80 do
begin
writeln('Informe o ', i ,'§ valor: ');
readln(n[i]);
end;
for i:= 1 to 80 do
begin
writeln(n[i]);
end;
m:=n[1];
p:=1;
for i:= 1 to 80 do
begin
if n[i]<m then
begin
m:=n[i];
p:=i;
end;
end;
writeln('O menor valor e: ', m, ' e esta na posicao ', p);
readkey;
end.
program ex51;
uses crt;
var
a: array[1..15] of integer;
aux, j, i: integer;
begin
clrscr;
for i:= 1 to 15 do
begin
writeln('Informe o ', i ,'§ valor: ');
readln(a[i]);
end;
writeln('Vetor original: ');
for i:= 1 to 15 do
begin
write(a[i]:5);
end;
for i:= 1 to 14 do
begin
for j:= i+1 to 15 do
begin
if a[i]>a[j] then
begin
aux:=a[i];
a[i]:=a[j];
a[j]:=aux;
end;
end;
end;
writeln;
writeln('Vetor em ordem crescente: ');
for i:= 1 to 15 do
begin
write(a[i]:5);
end;
readkey;
end.
52. Escrever um algoritmo/programa em Pascal que lê um vetor N[20] e o escreve. Troque, a seguir, o 1º elemento com o último, o 2º com o penúltimo, etc., até o 10º com o 11º e escreva o vetor N assim modificado.
program ex52;
uses crt;
var
n: array[1..20] of integer;
aux, i: integer;
begin
clrscr;
for i:= 1 to 20 do
begin
writeln('Informe o ', i ,'§ valor: ');
readln(n[i]);
end;
writeln('Vetor original: ');
for i:= 1 to 20 do
begin
write(n[i]:5);
end;
for i:= 1 to 10 do
begin
aux:=n[i];
n[i]:=n[21-i];
n[21-i]:=aux;
end;
writeln;
writeln('Vetor alterado: ');
for i:= 1 to 20 do
begin
write(n[i]:5);
end;
readkey;
end.
53. Escrever um algoritmo/programa em Pascal que lê um vetor K(20) e o escreve. Troque, a seguir, os elementos de ordem ímpar com os de ordem par imediatamente seguintes e escreva o vetor k modificado.
program ex53;
uses crt;
var
k: array[1..20] of integer;
aux, i: integer;
begin
clrscr;
for i:= 1 to 20 do
begin
writeln('Informe o ', i ,'§ valor: ');
readln(k[i]);
end;
writeln('Vetor original: ');
for i:= 1 to 20 do
begin
write(k[i]:5);
end;
for i:= 1 to 20 do
begin
if i mod 2<>0 then
begin
aux:=k[i];
k[i]:=k[i+1];
k[i+1]:=aux;
end;
end;
writeln;
writeln('Vetor alterado: ');
for i:= 1 to 20 do
begin
write(k[i]:5);
end;
readkey;
end.
54. Escrever um algoritmo/programa em Pascal que lê um vetor N[20] e o escreve. Troque, a seguir, o 1º elemento com 11º, o 2º com o 12º, etc., até o 10º com o 20º e escreva o vetor assim modificado.
program ex54;
uses crt;
var
n: array[1..20] of integer;
aux, i: integer;
begin
clrscr;
for i:= 1 to 20 do
begin
writeln('Informe o ', i ,'§ valor: ');
readln(n[i]);
end;
writeln('Vetor original: ');
for i:= 1 to 20 do
begin
write(n[i]:5);
end;
for i:= 1 to 10 do
begin
aux:=n[i];
n[i]:=n[10+i];
n[10+i]:=aux;
end;
writeln;
writeln('Vetor alterado: ');
for i:= 1 to 20 do
begin
write(n[i]:5);
end;
readkey;
end.
55. Escrever um algoritmo/programa em Pascal que lê um vetor G[20] (gabarito) e a seguir lê um número não determinado de números de alunos e vetores R[20] (resposta), um número e um vetor R de cada vez. O número representa o número de um aluno e o vetor R representa o conjunto de respostas daquele aluno. Para cada aluno calcular o nº de acertos e ca1cular a nota.
nota = número de acertos * 0.5
Escrever o nº do aluno, sua nota e a mensagem "aprovado" se tiver nota maior ou igual a 5 ou "reprovado" se a nota for menor do que 5.
program ex55;
uses crt;
var
g, r:array[1..20] of integer;
numal, acertos, i: integer;
nota: real;
begin
clrscr;
writeln('Informe o Gabarito: ');
for i:= 1 to 20 do
begin
write('Resposta ',i,': ');
readln(g[i]);
end;
repeat
clrscr;
writeln('Informe o Numero do Aluno (0 para sair): ');
readln(numal);
if numal>0 then
begin
writeln('Informe as respostas do aluno ',numal);
for i:= 1 to 20 do
begin
write('Resposta ',i,': ');
readln(r[i]);
end;
acertos:=0;
for i:= 1 to 20 do
begin
if r[i]=g[i] then
begin
acertos:=acertos+1;
end;
end;
nota:=acertos * 0.5;
writeln('O aluno ', numal, ' obteve a nota ', nota:0:1);
if nota>=5 then
begin
writeln('Esta aprovado!')
end
else
begin
writeln('Esta reprovado!');
end;
readkey;
end;
until numal=0;
end.
56. Escrever um algoritmo/programa em Pascal que lê 2 vetores K[10] e N[10] e os escreve. Crie, a seguir, um vetor M que seja a diferença entre K e N (M = K - N) e escreva o vetor M.
program ex56;
uses crt;
var
k, n, m: array[1..10] of integer;
i: integer;
begin
clrscr;
for i:= 1 to 10 do
begin
writeln('Informe o ', i ,'§ valor do vetor N: ');
readln(n[i]);
end;
for i:= 1 to 10 do
begin
writeln('Informe o ', i ,'§ valor do vetor K: ');
readln(k[i]);
end;
for i:= 1 to 10 do
begin
m[i]:=k[i]-n[i];
end;
writeln('Vetor N: ');
for i:= 1 to 10 do
begin
write(n[i]:5);
end;
writeln;
writeln('Vetor K: ');
for i:= 1 to 10 do
begin
write(k[i]:5);
end;
writeln;
writeln('Vetor M: ');
for i:= 1 to 10 do
begin
write(m[i]:5);
end;
readkey;
end.
57. Escrever um algoritmo/programa em Pascal que lê um vetor G[13] que é o Gabarito de um teste da loteria esportiva, contendo os valores 1 (coluna 1), 2(coluna 2), e 3 (coluna do meio). Ler, a seguir, para cada apostador, o nº de seu cartão e um vetor Resposta R[13]. Verificar para cada apostador o nº de acertos e escrever o nº do apostador e seu número de acertos. Se tiver 13 acertos, acrescentar a mensagem: "ganhador, parabéns!".
program ex57;
uses crt;
var
g, r:array[1..13] of integer;
numcart, acertos, i: integer;
begin
clrscr;
writeln('Informe o Resultado da Loteria (Gabarito): ');
for i:= 1 to 13 do
begin
write('Jogo ',i,': ');
readln(g[i]);
end;
repeat
clrscr;
writeln('Informe o Numero do Cartao (0 para sair): ');
readln(numcart);
if numcart>0 then
begin
writeln('Informe as respostas do cartao ',numcart);
for i:= 1 to 13 do
begin
write('Jogo ',i,': ');
readln(r[i]);
end;
acertos:=0;
for i:= 1 to 13 do
begin
if r[i]=g[i] then
begin
acertos:=acertos+1;
end;
end;
writeln('O cartao ', numcart, ' obteve ', acertos,' acertos!');
if acertos=13 then
begin
writeln('Ganhador, Parabens!')
end;
readkey;
end;
until numcart=0;
end.
58. Escrever um algoritmo/programa em Pascal que lê, um vetor V[20] e o escreve. Compacte, a seguir, o vetor Y, retirando dele todos os valores nulos ou negativos e escreva o vetor compactado.
program ex58;
uses crt;
var
v, y: array[1..20] of integer;
cont, i: integer;
begin
clrscr;
for i:= 1 to 20 do
begin
writeln('Informe o ',i, '§ valor: ');
readln(v[i]);
end;
cont:=0;
for i:= 1 to 20 do
begin
if v[i]>0 then
begin
cont:=cont+1;
y[cont]:=v[i];
end;
end;
clrscr;
writeln('Vetor original:');
for i:= 1 to 20 do
begin
write(v[i]:5);
end;
writeln;
writeln('Vetor compactado: ');
for i:= 1 to cont do
begin
write(y[i]:5);
end;
readkey;
end.
59. Escrever um algoritmo/programa em Pascal que lê um vetor V(20) e o escreve. Retire, a seguir, os elementos em duplicata, compactando o vetor Y, e escrevendo o vetor compactado.
program ex59;
uses crt;
var
v, y: array[1..20] of integer;
contpos,cont, i, j: integer;
begin
clrscr;
for i:= 1 to 20 do
begin
writeln('Informe o ',i, '§ valor: ');
readln(v[i]);
end;
contpos:=0;
for i:= 1 to 20 do
begin
cont:=0;
for j:=1 to contpos do
begin
if y[j]=v[i] then
begin
cont:=cont+1;
end;
end;
if cont=0 then
begin
contpos:=contpos+1;
y[contpos]:=v[i];
end;
end;
clrscr;
writeln('Vetor original:');
for i:= 1 to 20 do
begin
write(v[i]:5);
end;
writeln;
writeln('Vetor compactado: ');
for i:= 1 to contpos do
begin
write(y[i]:5);
end;
readkey;
end.
61. Escrever um algoritmo/programa em Pascal que lê o 1º termo e a razão de uma progressão aritmética e gera os vinte termos seguintes desta progressão, armazenando-os em 2 vetores de 10 elementos cada, no 1º os termos de ordem ímpar de geração e no 2º os de ordem par de geração. Escreva a seguir os 2 vetores de forma que os termos apareçam na ordem em que foram gerados.
program ex61;
uses crt;
var
vpar, vimpar: array[1..10] of integer;
t1, r, x, i: integer;
begin
clrscr;
writeln('1.o termo: ');
readln(t1);
writeln('Razao: ');
readln(r);
x:=t1;
for i:= 1 to 10 do
begin
vimpar[i]:=x;
x:=x+r;
vpar[i]:=x;
x:=x+r;
end;
for i:= 1 to 10 do
begin
write(vimpar[i]:5, vpar[i]:5);
end;
readkey;
end.
62. Escrever um algoritmo/programa em Pascal que gera os 10 primeiros números primos acima de 100 e os armazena em um vetor X(10) escrevendo, no final, o vetor X.
program ex62;
uses crt;
var
x: array[1..10] of integer;
i, num, contdiv, contprimo: integer;
begin
clrscr;
contprimo:=0;
num:=100;
repeat
num:=num+1;
contdiv:=0;
for i:= 1 to num do
begin
if num mod i=0 then
begin
contdiv:=contdiv+1;
end;
end;
if contdiv<=2 then
begin
contprimo:=contprimo+1;
x[contprimo]:=num;
end;
until contprimo=10;
writeln('Os numeros primos sao: ');
for i:= 1 to 10 do
begin
writeln(x[i]);
end;
readkey;
end.
63. Escreva um algoritmo/programa em Pascal que lê uma matriz M(5,5) e calcula as somas:
a) da linha 4 de M
b) da coluna 2 de M
c) da diagonal principal
d) da diagonal secundária
e) de todos os elementos da matriz
Escreva estas somas e a matriz.
program ex63;
uses crt;
var
m: array[1..5,1..5] of integer;
i, j, sl4, sc2, sdp, sds, soma: integer;
begin
sl4:=0; sc2:=0;
sdp:=0; sds:=0;
soma:=0;
clrscr;
writeln('Informe a matriz: ');
for i:= 1 to 5 do
begin
for j:= 1 to 5 do
begin
gotoxy(j*6,i+1);
readln(m[i,j]);
end;
end;
clrscr;
writeln('Matriz: ');
for i:= 1 to 5 do
begin
for j:= 1 to 5 do
begin
gotoxy(j*6,i+1);
write(m[i,j]:6);
end;
end;
for j:= 1 to 5 do
begin
sl4:=sl4+m[4,j];
end;
for i:= 1 to 5 do
begin
sc2:=sc2+m[i,2];
end;
for i:= 1 to 5 do
begin
sdp:=sdp+m[i,i];
sds:=sds+m[i,6-i];
end;
for i:= 1 to 5 do
begin
for j:= 1 to 5 do
begin
soma:=soma+m[i,j];
end;
end;
writeln;
writeln('Soma linha 4: ',sl4);
writeln('Soma coluna 2: ',sc2);
writeln('Soma diagonal principal: ',sdp);
writeln('Soma diagonal secundaria: ',sds);
writeln('Soma de toda matriz: ',soma);
readkey;
end.
64. Escrever um algoritmo/programa em Pascal que lê uma matriz M(6,6) e calcula as somas das partes hachuriadas.
x X X X X X X X X X X x x X X X X x x x x x x x
x x X X X X X X X X x x x x X X x x X x x x x x
x x x X X X X X X x x x x x x x x x X X x x x x
x x x x X X X X x x x x x x x x x x X X x x x x
x x x x x X X x x x x x x x x x x x X x x x x x
x x x x x x x x x x x x x x x x x x x x x x x x
Escrever a matriz M e as somas calculadas
65. Escrever um algoritmo/programa em Pascal que lê uma matriz M(10,10) e a escreve. Troque, a seguir:
- a linha 2 com a linha 8.
- a coluna 4 com a coluna 10
- a diagonal principal com a secundária
- a linha 5 com a coluna 10
Escreva a matriz assim modificada.
program ex65;
uses crt;
var
m: array[1..10,1..10] of integer;
aux, i, j: integer;
begin
clrscr;
writeln('Informe a matriz: ');
for i:= 1 to 10 do
begin
for j:= 1 to 10 do
begin
gotoxy(j*6,i+1);
{readln(m[i,j]);}
m[i,j]:=(i-1)*10+j;
end;
end;
clrscr;
writeln('Matriz: ');
for i:= 1 to 10 do
begin
for j:= 1 to 10 do
begin
gotoxy(j*6,i+1);
write(m[i,j]:6);
end;
end;
readkey;
clrscr;
writeln('Troca da linha 2 com a linha 8:');
for j:= 1 to 10 do
begin
aux:=m[2,j];
m[2,j]:=m[8,j];
m[8,j]:=aux;
end;
for i:= 1 to 10 do
begin
for j:= 1 to 10 do
begin
gotoxy(j*6,i+1);
write(m[i,j]:6);
end;
end;
readkey;
clrscr;
writeln('Troca da coluna 4 com a coluna 10:');
for i:= 1 to 10 do
begin
aux:=m[i,4];
m[i,4]:=m[i,10];
m[i,10]:=aux;
end;
for i:= 1 to 10 do
begin
for j:= 1 to 10 do
begin
gotoxy(j*6,i+1);
write(m[i,j]:6);
end;
end;
readkey;
clrscr;
writeln('Troca da diagonal principal com a secundaria:');
for i:= 1 to 10 do
begin
aux:=m[i,i];
m[i,i]:=m[i,11-i];
m[i,11-i]:=aux;
end;
for i:= 1 to 10 do
begin
for j:= 1 to 10 do
begin
gotoxy(j*6,i+1);
write(m[i,j]:6);
end;
end;
readkey;
clrscr;
writeln('Troca da linha 5 com a coluna 10:');
for i:= 1 to 10 do
begin
aux:=m[5,i];
m[5,i]:=m[i,10];
m[i,10]:=aux;
end;
for i:= 1 to 10 do
begin
for j:= 1 to 10 do
begin
gotoxy(j*6,i+1);
write(m[i,j]:6);
end;
end;
readkey;
end.