18.01.2018, 04:45 [+3 UTC]
в нашей команде: 2 478 чел. | участники онлайн: 0 (рекорд: 21)

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

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

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

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

:: правила

:: новости

:: участники

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

:: форум

:: блоги

:: поиск

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

:: наш журнал

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

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

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

:: поддержка

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

Версия системы:
7.42 (30.12.2017)

Общие новости:
02.01.2018, 09:46

Форум:
12.01.2018, 10:25

Последний вопрос:
18.01.2018, 01:11

Последний ответ:
18.01.2018, 00:46

Последняя рассылка:
17.01.2018, 23:15

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

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

Наша кнопка:

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

Отзывы о нас:
06.06.2010, 21:11 »
Поттер Г.
Большое спасибо за помощь [вопрос № 178891, ответ № 261895]
25.07.2010, 18:11 »
Kosowichev
спасибо, в пн попробую [вопрос № 179578, ответ № 262646]
06.04.2010, 20:15 »
Xrom1989
Verena, большое спасибо, особенно за вторую часть. Там все что мне надо для следующих задач=) [вопрос № 177620, ответ № 260643]

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

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

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

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

Зенченко Константин Николаевич
Статус: Модератор
Рейтинг: 374
Вадим Исаев ака sir Henry
Статус: Старший модератор
Рейтинг: 57
Евгений/Genia007/
Статус: Профессионал
Рейтинг: 20

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

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

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