Технический форум

Технический форум (http://www.tehnari.ru/)
-   Помощь студентам (http://www.tehnari.ru/f41/)
-   -   Несколько заданий в Паскале (http://www.tehnari.ru/f41/t73493/)

Arator 19.05.2012 12:29

Несколько заданий в Паскале
 
Помогите пожалуйста кто сможет. У меня через два дня экзамен я решить эти задачи не могу(((
1) Создать текстовый файл с несколькими строками. Отыскать и вывести самую длинную и самую короткую строку из указанного текстового файла.
2) Создать матрицу 4 × 4: Найти сумму элементов, которые находятся ниже побочной диагонали, сумму элементов, находящихся на основной диагонали.
3) Создать матрицу 4 × 4: Найти сумму элементов, которые находятся выше основной диагонали; сумму элементов, которые находятся на боковой диагонали.
4) Разработать программу создания текстового файла, который содержит матрицу случайных чисел заданного размера из указанного диапазона целых чисел и находит простые числа.
5) Создать массив случайных трехзначных целых чисел (N <= 30). Найти самую большую цифру каждого числа. Использовать рекурсивную функцию нахождения самой большой цифры числа.
6) Создать массив случайных четырехзначных целых чисел (N <= 30). Найти число, которое содержит наибольшее количество нулей. Использовать рекурсивную функцию нахождения количества нулей числа.
7) Создать матрицу 3 × 4 из случайных чисел из диапазона [-20; +20]. Вычислить: количество положительных чисел, количество отрицательных чисел,
8) Задан массив случайных целых 4-значных чисел размером N <= 20. Найти совершенные числа (число = сумме делителей).
9) Задано целое натуральное число, определить является ли оно факториал числа n, чему равна n. Использовать рекурсивную функцию вычисления факториала.
10) Задан массив положительных случайных 4-значных чисел размером N <= 20. Найти сумму цифр каждого числа. Использовать рекурсивную функцию.

Vladimir_S 19.05.2012 13:42

Цитата:

Сообщение от Arator (Сообщение 734586)
8) Задан массив случайных целых 4-значных чисел размером N <= 20. Найти совершенные числа (число = сумме делителей).

Пожалуйста, но уж больно глупая формулировка. Единственным совершенным четырехзначным числом является
8128 = 4064+2032+1016+508+254+127+64+32+16+8+4+2+1
и вероятность того, что оно сгенерируется, близка к нулю.
Код:

Var
 N,k:Byte;
 V:Integer;

Function Ideal(W:Integer):Boolean;
var
 i,Sum:Integer;
begin
 Sum:=0;
 For i:=1 to (W div 2) do
  If (W mod i)=0 then Inc(Sum,i);
 Ideal:=(Sum=W);
end;

Begin
 Write('N(<21)= ');
 Readln(N);
 Randomize;
 For k:=1 to N do
  begin
  V:=Random(9000)+1000;
  Writeln(V,' ',Ideal(V));
  end;
 Readln
End.


Arator 19.05.2012 14:04

Спасибо большое!

Arator 19.05.2012 14:20

Кто еще с какой то задач сможет помочь??? Пожалуйста)

Arator 19.05.2012 22:58

Народ помогитеееее....

Gruvi 20.05.2012 01:06

первая задача валялась у меня на компе, она считает самую короткую строку, остальное думаю сам доработаешь.
Цитата:

Uses crt;
Var p: text;
i, n, dlinS, dlinMin: byte;
s,min: string;
Begin
ClrScr;
Assign(p,'d:\myfile'); rewrite(p);

write('Количество строк: '); readln(n);
writeln('Введите строки ');
for i:=1 to n do
begin
write(i,': '); readln(s);
writeln (p,s);
end;
Close (p);

Assign(p,'d:\myfile'); reset(p);

read(p,s); min:=s;

for i:=1 to n do
begin
readln(p,s);
dlinS:=length(s); {длина строки}
dlinMin:=length(min); {длина min строки}
if dlinS<dlinMin then min:=s; {нахождение минимальной строки}
end;
close(p);
while not eof(p) do
begin
readln(p,s);
if length(s) < length(min) then min:=s;
end;
writeln('Самая короткая строка: ', min);
Readln
End.

Gruvi 20.05.2012 01:07

Вот программу еще нашел, считает самое длинное и самое короткое СЛОВО

Цитата:

Unit Z24;
Interface
Implementation
Begin
writeln('Определить самое короткое и самое длинное слово в строке введённой с клавиатуры');
End.

Program z24;

Uses z24.pas; {* Эту строку можно удалить *}
Uses crt; {* Подключение модулей *}
Var {* В работе нам потребуются переменные: *}
i : longint;
l : longint;
min : longint;
max : longint;
p1 : longint;
p2 : longint;
j : longint;
a : String;
b : String;
t1 : Array[1..60] Of String;
t2 : Array[1..60] Of longint;
Begin
clrscr; {* Стираем всё с экрана *}
textcolor(11); {* Светло-сине-зеленый текст *}
write('введите текст: ');
readln(a);
l := length(a) + 1;
a[l] := ' ';
For i := 1 To l Do {* Увеличиваем i от 1 до l с шагом 1 *}
If a[i] = ' ' Then
Begin
inc(j); {* Увеличиваем j на 1 *}
t1[j] := b;
t2[j] := length(b);
b := '';
End;
Else b := b + a[i];
max := t2[1];
min := t2[1];
p1 := 1;
p2 := 1;
For i := 1 To j Do {* Переменная i увеличивается с 1 до j *}
Begin
If maxt2[i] Then
Begin
min := t2[i];
p2 := i;
End;

End;
writeln('самое длинное слово: ', t1[p1]);
writeln('самое короткое слово: ', t1[p2]);
textcolor(13); {* Розовый текст *}
write('P.S.');
writeln(' Если слово не выведено на печать, то вы ');
write(' поставили несколько подряд идущих пробелов!');
readln; {* Ждем нажатия Enter *}
End.


Часовой пояс GMT +4, время: 17:10.

Powered by vBulletin® Version 4.5.3
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.