24.09.2017, 20:31 [+3 UTC]
в нашей команде: 2 128 чел. | участники онлайн: 2 (рекорд: 21)

:: РЕГИСТРАЦИЯ

:: консультации

:: задать вопрос

:: все разделы

:: правила

:: новости

:: участники

:: доска почёта

:: форум

:: блоги

:: поиск

:: статистика

:: наш журнал

:: наши встречи

:: наша галерея

:: отзывы о нас

:: поддержка

:: руководство

Версия системы:
7.41 (25.02.2017)

Общие новости:
23.02.2017, 09:51

Форум:
24.09.2017, 16:39

Последний вопрос:
24.09.2017, 14:40

Последний ответ:
24.09.2017, 15:05

Последняя рассылка:
24.09.2017, 14:15

Писем в очереди:
0

Мы в соцсетях:

Наша кнопка:

RFpro.ru - здесь вам помогут!

Отзывы о нас:
21.04.2010, 19:31 »
Гречко Альберт Алексеевич
Спасибо за обстоятельный и полный ответ. [вопрос № 177918, ответ № 260909]
06.05.2016, 00:57 »
region41
Не смог найти в сети доступного объяснения на свой вопрос, Игорь Витальевич разложил все по полочкам. Большое спасибо! [вопрос № 189297, ответ № 273748]

РАЗДЕЛ • Pascal / Delphi / Lazarus

Создание программ на языках Pascal, Delphi и Lazarus.

[администратор рассылки: Зенченко Константин Николаевич (Модератор)]

Лучшие эксперты в этом разделе

Зенченко Константин Николаевич
Статус: Модератор
Рейтинг: 249
Вадим Исаев ака sir Henry
Статус: Старший модератор
Рейтинг: 49
Асмик Гаряка
Статус: Советник
Рейтинг: 0

Перейти к консультации №:
 

Консультация онлайн # 190341
Раздел: • Pascal / Delphi / Lazarus
Автор вопроса: dinar.ahmetov.2598 (Посетитель)
Отправлена: 25.12.2016, 15:56
Поступило ответов: 1

Здравствуйте! У меня возникли сложности с таким вопросом:

В одномерном массиве А(I), элементами которого являются положительные и отрицательные целые числа, вводимые с клавиатуры определите максимальное из отрицательных элементов массива. Сформируйте новый массив В(I), заменив положительные элементы массива найденным максимумом из отрицательных элементов массива А(I)

Состояние: Консультация закрыта

Ответ # 274472 от mklokov (6-й класс)

Здравствуйте, dinar.ahmetov.2598!

Код (Pascal) :: выделить код
Const N=10;
Var a, b: array[1..N] of Integer;
i, PosMaxNegative: Integer;
begin
  PosMaxNegative:=0;
  for i:=1 to N do
  begin
    read(a[i]);
    if a[i]<0 then
      PosMaxNegative:=i;
  end;
  writeln;
  if PosMaxNegative>0 then
  begin
    for i:=1 to n do
      if (a[i] < 0) and (a[i]>a[PosMaxNegative]) then
        PosMaxNegative:=i;
      for i:=1 to N do
      begin
        if a[i]>0 then{тут ошибка искались отрицательные числа, а нужны были положительные}
          b[i]:=a[PosMaxNegative]
        else
          b[i]:=a[i];
        write(b[i],' ')
      end
    end
  else
    write('Нет ни одного отрицательного числа')
end.

Примеры работы кода(см. комментарий в коде: был перепутан ">" и "<" К.Зенченко):
Ввод:
5 11 -1 9 -3 -7 8 4 -2 2

Вывод:
5 11 -1 9 -1 -1 8 4 -1 2


Ввод:
1 1 2 3 4 5 6 7 8 9

Вывод:
Нет ни одного отрицательного числа

уточненно задание, добаблен тег-pascal(a/a)
--------

• Отредактировал: Зенченко Константин Николаевич (Модератор)
• Дата редактирования: 29.12.2016, 22:34


Консультировал: mklokov (6-й класс)
Дата отправки: 25.12.2016, 21:44

Рейтинг ответа:

0

[подробно]

Сообщение
модераторам

Отправлять сообщения
модераторам могут
только участники портала.
ВОЙТИ НА ПОРТАЛ »
регистрация »

Мини-форум консультации № 190341
mklokov
6-й класс

ID: 400828

# 1

= общий = | 26.12.2016, 01:09 | цитировать цитировать  | профиль профиль  |  отправить письмо в личную почту пейджер

Сорри, допустил ошибку.
Вместо:
if a[i]<0 then
Должно быть:
if a[i]>0 then

Зенченко Константин Николаевич
Модератор

ID: 31795

# 2

= общий = | 26.12.2016, 18:37 | цитировать цитировать  | профиль профиль  |  отправить письмо в личную почту пейджер
dinar.ahmetov.2598:

© Цитата: mklokov
Сорри, допустил ошибку.


Слишком много этих IF'ов, исправленный вариант:
Код (Pascal) :: выделить код
Const N=10;
Var a, b: array[1..N] of Integer;
i, PosMaxNegative: Integer;
begin
  PosMaxNegative:=0;
  for i:=1 to N do
  begin
    read(a[i]);
    if a[i]<0 then
      PosMaxNegative:=i;
  end;
  writeln;
  if PosMaxNegative>0 then
  begin
    for i:=1 to n do
      if (a[i] < 0) and (a[i]>a[PosMaxNegative]) then
        PosMaxNegative:=i;
      for i:=1 to N do
      begin
        if a[i]>0 then{тут ошибка}
          b[i]:=a[PosMaxNegative]
        else
          b[i]:=a[i];
        write(b[i],' ')
      end
    end
  else
    write('Нет ни одного отрицательного числа')
end.

Зенченко Константин Николаевич
Модератор

ID: 31795

# 3

= общий = | 26.12.2016, 18:39 | цитировать цитировать  | профиль профиль  |  отправить письмо в личную почту пейджер
mklokov:


Когда указываете на ошибку - указывайте строки кода.

 

Возможность оставлять сообщения в мини-форумах консультаций доступна только после входа в систему.
Воспользуйтесь кнопкой входа вверху страницы, если Вы зарегистрированы или пройдите простую процедуру регистрации на Портале.

Яндекс Rambler's Top100

главная страница | поддержка | задать вопрос

Время генерирования страницы: 0.14073 сек.

© 2001-2017, Портал RFPRO.RU, Россия
Авторское право: ООО "Мастер-Эксперт Про"
Калашников О.А.  |  Гладенюк А.Г.
Версия системы: 7.41 от 25.02.2017
Бесплатные консультации онлайн