• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

    Если вы у нас впервые, загляните на страницу о форуме и правила – там коротко описано, как задать вопрос так, чтобы быстро получить ответ. Чтобы создавать темы и писать сообщения, сначала зарегистрируйтесь, а затем войдите под своим логином.

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по старой ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Несколько заданий в Паскале

  • Автор темы Автор темы Arator
  • Дата начала Дата начала

Arator

Новые
Регистрация
18 Май 2012
Сообщения
14
Реакции
0
Баллы
0
Несколько заданий в Паскале

Помогите пожалуйста кто сможет. У меня через два дня экзамен я решить эти задачи не могу(((
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. Найти сумму цифр каждого числа. Использовать рекурсивную функцию.
 
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.
 
Спасибо большое!
 
Кто еще с какой то задач сможет помочь??? Пожалуйста)
 
Народ помогитеееее....
 
первая задача валялась у меня на компе, она считает самую короткую строку, остальное думаю сам доработаешь.
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.
 
Вот программу еще нашел, считает самое длинное и самое короткое СЛОВО

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 = ' ' Then
Begin
inc(j); {* Увеличиваем j на 1 *}
t1[j] := b;
t2[j] := length(b);
b := '';
End;
Else b := b + a;
max := t2[1];
min := t2[1];
p1 := 1;
p2 := 1;
For i := 1 To j Do {* Переменная i увеличивается с 1 до j *}
Begin
If maxt2 Then
Begin
min := t2;
p2 := i;
End;

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