Решать надо примерно так:
Создать массив целых чисел(к примеру на 20 элементов)
Объявить две переменные(счётчик и B)
Написать пользователю чтобы он ввёл значение для B
Заполнить массив числами через цикл for и генератор псевдо-слуайных чисел(к примеру от 0 до 50)
Всё в том же цикле сделать условие типа "если a[i] > B и если a[i] % 5 == 0(делится на 5 без остатка)", то увеличить счётчик на единицу, и после этого условия вывести значение элемента в строчку через пробел
Ну и в конце вывести значение счётчика.
В паскале не разбираюсь, поэтому вот пример решения на C++
#include <iostream>
using std::cout;
using std::cin;
using std::endl;
#include <cstdlib>
using std::rand;
using std::srand;
#include <ctime>
using std::time;
int main()
{
int a[20], counter = 0, b;
srand(time(0));
cout << "Enter B: ";
cin >> b;
for(int i = 0; i < 20; i++)
{
a[i] = rand() % 51;
if(a[i] > b && a[i] % 5 == 0)
{
counter++;
}
cout << a[i] << ' ';
}
cout << "\n" << counter << " numbers" << endl;
cin.get();
return 0;
}
// Внимание! Если программа не работает, обновите версию!
function SumD(n:integer):integer;
begin
Result:=0;
while n>0 do begin
Result+=n mod 10;
n:=n div 10
end
end;
begin
var a:=ArrRandom(ReadInteger('n='),1,999); a.Println;
a:=a.OrderBy(x->x).OrderBy(x->SumD(x)).ToArray;
a.Println;
end.
Пример
n= 30
632 411 647 143 933 205 451 16 213 479 106 939 299 315 566 428 306 758 495 927 101 301 599 969 368 180 24 124 739 635
101 301 24 213 411 16 106 124 205 143 180 306 315 451 632 428 635 933 368 566 647 495 927 739 299 479 758 939 599 969