Форум программистов, компьютерный форум, киберфорум
PascalABC.NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
0 / 0 / 0
Регистрация: 29.05.2018
Сообщений: 4

Найти два элемента массива, сумма которых наименее близка к данному числу R

12.06.2018, 17:54. Показов 753. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дано вещественное число R и массив размера n. Найти два элемента массива, сумма которых наименее близка к данному числу R.

Решение данной задачи необходимо оформить с помощью процедур. Помогите исправить типы данных в процедуре work.

Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
Program zadanie_5_1_9;
const nmax=100;
type mas=array[1..nmax] of integer;
procedure Generate(var a:mas;var n:byte);
var i1,i2:integer;
    i:byte;
begin
repeat
write('Размер массива до ',nmax,' =');
readln(n);
until n in [1..nmax];
repeat
writeln('Введите границs диапазона случайных чисел i1<i2:');
readln(i1,i2);
until i1<i2;
for i:=1 to n do
a[i]:=random(i2-i1+1)+i1;
end;
procedure Vyvod(var a:mas;n:byte);
var i:byte;
begin
for i:=1 to n do
write(a[i]:4);
writeln;
end;
procedure Work(var r:real; a:mas;n:byte);
var i,j,max,min,s,imin,jmin,imax,jmax:real;
begin
 write ('Введите R: '); 
 readln (r);
 max:=1e38; min:=-1e38;
 for i:=1 to n-1 do
 for j:=i+1 to n do begin
  s:=a[i]+a[j];
  if abs(s-r)<min then begin
   min:=abs(s-r); imin:=i; jmin:=j;
  end;
  if abs(s-r)>max then begin
   max:=abs(s-r); imax:=i; jmax:=j;
  end;
 end;
 writeln ('Наиболее близки к r: a[',imin,'] и a[',jmin,'], сумма=',(a[imin]+a[jmin]):8:2);
 writeln ('Наименее близки к r: a[',imax,'] и a[',jmax,'], сумма=',(a[imax]+a[jmax]):8:2);
 writeln;
 readln;
end;
begin
writeln ('Дано вещественное число R и массив размера n. Найти два элемента массива, сумма которых наименее близка к данному числу R.');
randomize;
Generate(a,n);
Vyvod(a,n);
Work(r,a,n);
end.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
12.06.2018, 17:54
Ответы с готовыми решениями:

найти два соседних элемента массива, сумма которых наиболее близка к числу R
дано число R и массив размера N. найти два соседних элемента массива, сумма которых наиболее близка к числу R, и вывести эти элементы в...

Найти два соседних элемента массива, сумма которых наиболее близка к числу R
дано число R и массив размера N. найти два соседних элемента массива, сумма которых наиболее близка к числу R, и вывести эти элементы в...

Дано число R и массив размера N. Найти два соседних элемента массива, сумма которых наиболее близка к числу R,и вывести эти элементы
Дано число R и массив размера N. Найти два соседних элемента мас- сива, сумма которых наиболее близка к числу R, и вывести эти элементы в...

1
Почетный модератор
 Аватар для Puporev
64315 / 47611 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
12.06.2018, 19:13
Цитата Сообщение от lady_Jane Посмотреть сообщение
Дано вещественное число R и массив размера n. Найти два элемента массива, сумма которых наименее близка к данному числу R.
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
const nmax=100;
type mas=array[1..nmax] of integer;
procedure Generate(var a:mas;var n:byte);
var i1,i2:integer;
    i:byte;
begin
repeat
write('Размер массива до ',nmax,' =');
readln(n);
until n in [1..nmax];
repeat
writeln('Введите границs диапазона случайных чисел i1<i2:');
readln(i1,i2);
until i1<i2;
for i:=1 to n do
a[i]:=random(i2-i1+1)+i1;
end;
procedure Vyvod(var a:mas;n:byte);
var i:byte;
begin
for i:=1 to n do
write(a[i]:4);
writeln;
end;
procedure Work(a:mas;n:byte);
var i,j,imax,jmax:integer;
    r,max,s:real;
begin
 write ('Введите R: ');
 readln (r);
 max:=abs(a[1]+a[2]-r);
 for i:=1 to n-1 do
 for j:=i+1 to n do
  begin
   s:=a[i]+a[j];
   if abs(s-r)>max then
    begin
     max:=abs(s-r);
     imax:=i;
     jmax:=j;
   end;
  end;
 writeln ('Наименее близки к r: a[',imax,'] и a[',jmax,'], сумма=',(a[imax]+a[jmax]));
end;
var a:mas;
    n,i:byte;
begin
writeln ('Дано вещественное число R и массив размера n. Найти два элемента массива, сумма которых наименее близка к данному числу R.');
randomize;
Generate(a,n);
Vyvod(a,n);
Work(a,n);
end.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.06.2018, 19:13
Помогаю со студенческими работами здесь

Найдите и выведите на экран все трехзначные числа, сумма цифр которых равна данному целому числу N
Всем привет. Нужно подробно объяснить решение задачи №2, надеюсь на ваши помощь друзья :)

Вычислить сумму ряда, полученная сумма должна быть близка к числу SQR(Pi)/8
сумма ряда 1/sqr(1)+1/sqr(3)+1/sqr(5)+1/sqr(7)+... сумма должна быть близка к числу SQR(Pi)/8 Program Sum; const...

Найти элемент массива, который наиболее близок к данному числу
Дано вещественное число R и массив размера N.Найти элемент массива,который наиболее близок к данному числу.

Найти сумму тех элементов массива, которые кратны данному числу 7
помогите пожалуйста решить задачу через паскаль В массив A занесены натуральные числа. Найти сумму тех элементов, которые кратны данному...

Найти количество элементов массива, у которых сумма и номера и элемента дают число кратное 7
1.Массив на 53 элемента заполнить случайным образом в интервале от 10 до 30. Найти количество элементов, у которых сумма и номера и...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
1С: Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью. Данные берутся из регистра сведений, по которому настроено. . .
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
1С: Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию группы. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
1С: Программный отбор элементов справочника по значению перечисления
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит значение перечислений. / / Событие "НачалоВыбора" реквизита на форме. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru