Форум программистов, компьютерный форум, киберфорум
Pascal (Паскаль)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/8: Рейтинг темы: голосов - 8, средняя оценка - 4.50
0 / 0 / 0
Регистрация: 04.12.2019
Сообщений: 12

Получить упорядоченный по возрастанию массив, состоящий из элементов первого массива, которых нет во втором

04.12.2019, 18:57. Показов 1685. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Народ, помогите, пожалуйста. Студенту нужна помощь. Ссаными тряпками не кидайтесь
Суть вопроса. Помогите с кодом для такого задания: Даны два упорядоченных по убыванию массива, получить упорядоченную по возрастанию массив, состоящий из элементов первого массива, которых нет во втором.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.12.2019, 18:57
Ответы с готовыми решениями:

Модульное программирование в Pascal
Огромная просьба в составлении программ: Составить модуль, реализующий алгоритмы проверки: является ли произвольная квадратная...

Object Pascal...Линейное программирование!
Составьте программу для вычисления времени t встречи автомобилей, движущихся равноускоренно навстречу друг другу, если известны их скорости...

Turbo Pascal, Pascal ABC, Free Pascal, PascalABC.NET - в чем разница?
Всем привет, решил изучать Паскаль, но на форуме увидел 4 его версии - Turbo Pascal, Pascal ABC, Free Pascal, PascalABC.NET и не понял, в...

4
Модератор
Эксперт Pascal/DelphiЭксперт NIX
 Аватар для bormant
7816 / 4635 / 2837
Регистрация: 22.11.2013
Сообщений: 13,158
Записей в блоге: 1
04.12.2019, 21:43
Лучший ответ Сообщение было отмечено ZX Spectrum-128 как решение

Решение

... только проход по исходным массивам делать с хвоста.

И да, код по предложенной ссылке нельзя назвать годным...

Добавлено через 26 минут
ZX Spectrum-128,
всего-то и нужно:
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
var
  a: array [0..9] of Integer;
  b: array [0..9] of Integer;
  c: array [0..High(a)-Low(a)+High(b)-Low(b)+2] of Integer;
  p, q, r: Integer;
begin
  for p:=Low(a) to High(a) do a[p]:=High(a)+1-p;
  for p:=Low(b) to High(b) do b[p]:=High(b)+7-p;
 
  p:=High(a); q:=High(b); r:=Low(c);
  while (p>=Low(a)) and (q>=Low(b)) do
    if a[p]<b[q] then begin
      c[r]:=a[p]; Inc(r); Dec(p);
    end else if a[p]>b[q] then begin
      c[r]:=b[q]; Inc(r); Dec(q); 
    end else begin
      Dec(p); Dec(q);
    end;
  for p:=p downto Low(a) do begin c[r]:=a[p]; Inc(r); end;
  for q:=q downto Low(b) do begin c[r]:=b[q]; Inc(r); end;
 
  Write('A:'); for p:=Low(a) to High(a) do Write(a[p]:4); WriteLn;
  Write('B:'); for p:=Low(b) to High(b) do Write(b[p]:4); WriteLn;
  Write('C:'); for p:=Low(с) to r-1     do Write(c[p]:4); WriteLn;
end.
Добавлено через 15 минут
Или, поскольку тема в общем разделе, без Low(), High():
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
const na=10; nb=10; nc=na+nb; W=4;
var
  a: array [0..na-1] of Integer;
  b: array [0..nb-1] of Integer;
  c: array [0..nc-1] of Integer;
  p, q, r: Integer;
begin
  for p:=0 to na-1 do a[p]:=na-p;
  for p:=0 to nb-1 do b[p]:=nb+6-p;
 
  p:=na-1; q:=nb-1; r:=0;
  while (p>=0) and (q>=0) do
    if a[p]<b[q] then begin
      c[r]:=a[p]; Inc(r); Dec(p);
    end else if a[p]>b[q] then begin
      c[r]:=b[q]; Inc(r); Dec(q); 
    end else begin
      Dec(p); Dec(q);
    end;
  for p:=p downto 0 do begin c[r]:=a[p]; Inc(r); end;
  for q:=q downto 0 do begin c[r]:=b[q]; Inc(r); end;
 
  Write('A:'); for p:=0 to na-1 do Write(a[p]:W); WriteLn;
  Write('B:'); for p:=0 to nb-1 do Write(b[p]:W); WriteLn;
  Write('C:'); for p:=0 to r-1  do Write(c[p]:W); WriteLn;
end.
2
0 / 0 / 0
Регистрация: 04.12.2019
Сообщений: 12
05.12.2019, 23:01  [ТС]
написал такой вод код. но при вводе 2го массива выдает ошибку 201. как я понимаю - это ошибка выхода за пределы массива. но при вводе 1го массива такой проблемы нет. в чем проблема?




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
const n=7;
var a, b, c: array[1..n] of integer;
    i, j, k, m: integer;
begin
   writeln ('введите 1 массив, чтобы каждый последующий элемент был меньше');
   i:= 1;
   while i <= n do begin
        read(a[i]);
        i:= i+1;
   end;
   for i:=1 to n do
        writeln ('a[',i,']=', a[i]);
 
 
   writeln ('введите 2 массив, чтобы каждый последующий элемент был меньше');
   j:= 1;
   while j <= n do begin
        read(b[j]);
        j:= j+1;
   end;
   for j:=1 to n do
        writeln ('b[',j,']=', b[j]);
 
   m:=0;
   for i:=n downto 1 do begin
   k:=1;
   while (m<=n) and (a[i]<>b[j]) do inc(k);
   if m>n then begin
   inc(m);
   c[k]:= a[i];
   end;
   end;
   for i:= 1 to k do
   writeln (c[k]);
   end;
end.
0
Модератор
Эксперт Pascal/DelphiЭксперт NIX
 Аватар для bormant
7816 / 4635 / 2837
Регистрация: 22.11.2013
Сообщений: 13,158
Записей в блоге: 1
06.12.2019, 10:09
Ошибка не при, а после ввода второго массива.
Нужно быть внимательнее, в третьем массиве места не хватает.
В худшем случае, туда должны поместиться все элементы и из a, и из b:
Pascal
1
2
3
4
var
  a: array [0..9] of Integer;
  b: array [0..9] of Integer;
  c: array [0..High(a)-Low(a)+High(b)-Low(b)+2] of Integer;
Pascal
1
2
3
4
5
const na=10; nb=10; nc=na+nb; W=4;
var
  a: array [0..na-1] of Integer;
  b: array [0..nb-1] of Integer;
  c: array [0..nc-1] of Integer;
Теперь сравните со своим вариантом.

Добавлено через 1 минуту
Pascal
1
2
var
  c: array [1..n*2] of Integer;
Добавлено через 3 минуты
Зачем при вводе while, если достаточно for?
Pascal
5
6
7
8
9
10
  WriteLn('введите 1 массив, чтобы каждый последующий элемент был меньше');
  for i:=1 to n do Read(a[i]);
  for i:=1 to n do WriteLn('a[',i,']=',a[i]);
  WriteLn('введите 2 массив, чтобы каждый последующий элемент был меньше');
  for i:=1 to n do Read(b[i]);
  for i:=1 to n do WriteLn('b[',i,']=',b[i]);
Добавлено через 4 минуты
Хозяйке на заметку: можно ввести в произвольном порядке, затем явно отсортировать по невозрастанию.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.12.2019, 10:09
Помогаю со студенческими работами здесь

Программирование на Pascal
Помогите написать программу

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

Программирование в Turbo Pascal
Всем доброго дня! Прошу помочь мне вот с чем. Дана функция ln!cosx!/ln(1+x^2) нужно её написать в Turbo Pascal?

Программирование на pascal под windows
Я начинающий в этой теме, переписал в pascal элементарную прогу из учебника: program HelloApp; uses WObjects; type ...

программирование Pascal ABC
Пожалуйста,помогите написать программы под 7 номером на каждой фотографии


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru