14.11.2018, 23:50 [+3 UTC]
в нашей команде: 3 105 чел. | участники онлайн: 7 (рекорд: 16)

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

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

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

:: правила

:: новости

:: участники

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

:: форум

:: блоги

:: поиск

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

:: наш журнал

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

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

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

:: поддержка

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

Версия системы:
7.55 (06.11.2018)

Общие новости:
24.09.2018, 16:49

Форум:
08.11.2018, 13:36

Последний вопрос:
14.11.2018, 22:15

Последний ответ:
14.11.2018, 10:15

Последняя рассылка:
14.11.2018, 18:46

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

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

Наша кнопка:

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

Отзывы о нас:
26.08.2010, 01:39 »
Фрицлер Игорь Карлович
Батарейку я заменил, но к сожалению забыл об этом написать-моя ошибка. Замена не повлияла. Спасибо, что откликнулись. [вопрос № 179779, ответ № 262882]
16.09.2009, 10:41 »
Admiral
Спасибо огромное за оперативный ответ!
01.10.2010, 11:45 »
Dipauler
Благодарю Вас за ответ. Пожалуй, так и поступлю. [вопрос № 180100, ответ № 263273]

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

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

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

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

Зенченко Константин Николаевич
Статус: Модератор
Рейтинг: 634
Степанов Иван /REDDS
Статус: 4-й класс
Рейтинг: 26
Асмик Гаряка
Статус: Советник
Рейтинг: 6

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

Консультация онлайн # 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.

=====
Мне безразлично, что Вы думаете о обо мне, но я рад за Вас - Вы начали думать.
smile

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

ID: 31795

# 3

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


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

=====
Мне безразлично, что Вы думаете о обо мне, но я рад за Вас - Вы начали думать.
smile

 

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

Яндекс Rambler's Top100

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

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

© 2001-2018, Портал RFPRO.RU, Россия
Калашников О.А.  |  Гладенюк А.Г.
Версия системы: 7.55 от 06.11.2018