С Новым годом! Форум программистов, компьютерный форум, киберфорум
Free Pascal
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 15.05.2016
Сообщений: 3
1

Получить массив В путем перебора элементов массива А с нечетным индексом

21.09.2016, 11:13. Показов 1173. Ответов 3

Author24 — интернет-сервис помощи студентам
Создать программу, в которой все данные будут размещаться динамически. Получить массив В путем перебора элементов массива А с нечетным индексом, стоящих правее максимального элемента. Отсортировать по убыванию методом пузырька. Помогите, где ошибка?

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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
   Program Z1_2_11;
  uses crt;
  type
   Arr=array [1..30] of integer;
   PArr=^Arr;
  var
   a,b:PArr;
   i,d,max,kl:integer;
   t:text;
   ch:char;
 
  Procedure VvodI (var ni:integer);
   begin
    repeat
     Writeln ('Vvedite kolichestvo elementov massiva');
     readln (ni);
     if ni<=0 then
      writeln ('Error!');
    until (ni>0);
    writeln (t,' kolichestvo elementov=',ni);
   end;
 
  Procedure ZapolnMas (ii:integer; var ai:PArr);
   var j:integer;
   Begin
    for j:=1 to ii do
     begin
      writeln ('Vvedite element [',j,']:');
      readln (ai^[j]);
      writeln (t,'    a[',j,']=',ai^[j]);
     end;
   end;
    procedure MaxR(var ai: parr; var t:text; ni:integer;max:integer;kl:integer);
  var
   k:integer;
  begin
   kl:=1;
   max:=ai^[1];
   for k:=1 to ni do
     if a^[k]>max then
     begin
      max:=ai^[k];
      kl:=k;
     end;
     writeln(t,'index max element =',kl);
     writeln(t,'max element=',max);
   end;
 
  Procedure Obrabotka (ii:integer; ai:PArr; var di:integer; var kl:integer);
   var j:integer;
   begin
    di:=0;
    for j:=kl to ii do
     if (j mod 2=1) then
      inc(di);
   end;
 
  Procedure ZapolnB (di,ii,kl:integer; ai:PArr; var bi:PArr);
   var j:integer;
   begin
    if (kl mod 2=1) then bi^[1]:=a^[kl];
    di:=1;
    for j:=kl to ii do
     if (j mod 2=1) and (j>=kl) then
      begin
 
       bi^[di]:=ai^[j];
       inc(di);
      end;
   end;
  Procedure Sortirovka (var bi:PArr; di:integer);
   var i,j,k:integer;
   begin
     for i:=1 to di do
      for j:=1 to di do
      if bi^[j]>bi^[j+1] then
       begin
        k:= bi^[j];
        bi^[j]:=bi^[j+1];
        bi^[j+1]:=k;
       end;
     for j:=1 to di do
      writeln (t,'    ',bi^[j],' ');
      writeln ('      ',bi^[j],' ');
   end;
 
 
  begin
   clrscr;
   assign (t,'z1_02.pas');
   append (t);
  repeat
   {writeln(t,' Available ',memavail ,' byte.');}
 
   VvodI (i);
 
   GetMem (a,sizeof(integer)*i);
   ZapolnMas (i,a);
   maxr(a,t,i,max,kl);
   Obrabotka (i,a,d,kl);
   GetMem(b,sizeof(integer)*d);
   ZapolnB (d,i,kl,a,b);
   writeln (t,'  Otvet:');
   Sortirovka (b,d);
   {writeln(t,' Available ',memavail ,' byte.'); }
 
   writeln(t,'-----------------------------------------');
   FreeMem (a,sizeof(integer)*i);
   FreeMem (b,sizeof(integer)*d);
   writeln ('Press 1');
   readln (ch);
  until (ch='1');
   close (t);
  end.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
21.09.2016, 11:13
Ответы с готовыми решениями:

Суммы элементов массива с четным и нечетным индексом
Массив N элементов. Отдельно сумма чисел , которые в массиве под четным числом(индексом) и отдельно...

Массив: Найти среднеарифметическое значение последних 10-и элементов и произведение элементов с нечетным индексом
Найти среднеарифметическое значение последних 10-и элементов и произведение элементов с нечетным...

Создать одномерный массив из 15 элементов,вычислить среднеарифметическое значение нечетных элементов с нечетным индексом
Создать одномерный массив из 15 элементов,вычислить среднеарифметическое значение нечетных...

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

3
Модератор
Эксперт Pascal/DelphiЭксперт NIX
7797 / 4620 / 2831
Регистрация: 22.11.2013
Сообщений: 13,119
Записей в блоге: 1
21.09.2016, 12:39 2
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

Какая именно ошибка вас интересует?

Добавлено через 8 минут
На первый взгляд, речь о
Pascal
58
Procedure ZapolnB (var di: Integer; ii,kl:integer; ai:PArr; var bi:PArr);
Добавлено через 6 минут
Кроме того, если речь о Free Pascal (о чем недвусмысленно намекает название раздела), то его компилятор поддерживает динамические массивы, не нужно изобретать велосипеда с GetMem/FreeMem:
Pascal
1
2
3
4
5
6
7
8
9
var
  a, b: array of Integer;
  t: Integer;
begin
  repeat Write('Размер A: '); ReadLn(t); until t>0;
  SetLength(a,t);
  Write('Элементы массива A: ');
  for t:=Low(a) to High(a) do Read(a[t]); ReadLn;
...
0
0 / 0 / 0
Регистрация: 15.05.2016
Сообщений: 3
21.09.2016, 12:42  [ТС] 3
Программа некорректно выдает результат, в массиве В первый элемент почему-то 0, и записывает программа все нечетные элементы из массива А, даже те, которые стоят левее максимального элемента, хотя так не должно быть

Добавлено через 56 секунд
Мне по заданию именно с этим всем нужно написать программу, увы(
0
Модератор
Эксперт Pascal/DelphiЭксперт NIX
7797 / 4620 / 2831
Регистрация: 22.11.2013
Сообщений: 13,119
Записей в блоге: 1
21.09.2016, 18:04 4
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

Проверяйте:
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
const W=4;
type
  PIntArr = ^TIntArr;
  TIntArr = array [1..$FFFE div SizeOf(Integer)] of Integer;
var
  pa, pb: PIntArr;
  na, nb, i, j, k, t: Integer;
begin
  Randomize;
  repeat Write('Размер A: '); ReadLn(na); until na>0;
  GetMem(pa,SizeOf(pa^[1])*na);
  for i:=1 to na do pa^[i]:=Random(100);
  Write('A ='); for i:=1 to na do Write(' ',pa^[i]:W); WriteLn;
  k:=1; for i:=2 to na do if pa^[i]>pa^[k] then k:=i;
  nb:=(na-k) div 2;
  if nb>0 then begin
    GetMem(pb,SizeOf(pb^[1])*nb);
    i:=(k+1) or 1; for j:=1 to nb do begin pb^[j]:=pa^[i]; Inc(i,2); end;
    i:=nb;
    repeat
      k:=1;
      for j:=1 to i-1 do
        if pb^[j+1]>pb^[j] then begin
          k:=j; t:=pb^[j]; pb^[j]:=pb^[j+1]; pb^[j+1]:=t;
        end;
      i:=k;
    until k=1;
    Write('B ='); for i:=1 to nb do Write(' ',pb^[i]:W); WriteLn;
    FreeMem(pb,SizeOf(pb^[1])*nb);
  end else WriteLn('Нет элементов с нечетными индексами после максимального');
  FreeMem(pa,SizeOf(pa^[1])*na);
end.
0
21.09.2016, 18:04
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
21.09.2016, 18:04
Помогаю со студенческими работами здесь

Найти сумму элементов массива с нечетным индексом, по модулю меньше K
По заданому условию сформировать одномерный массив (вектор), вывести на печать и произвести...

Динамический массив: Определить сумму и количество элементов, предшествующих последнему четному числу с нечетным индексом
Задан одномерный динамический массив.Определить сумму и количество всех элементов,предшествующих...

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

Дан массив a[n,m]. Получить новый массив путем деления всех элементов исходного массива на элемент, наименьший по модулю
Дан массив a. Получить новый массив путем деления всех элементов исходного массива на элемент,...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
UserScript для подсветки кнопок языков программировани­­­я в зависимости от текущего раздела
volvo 13.01.2025
В результате работы этого скрипта подсвечиваются нужные кнопки не только в форм быстрого ответа, но и при редактировании сообщения: / / ==UserScript== / / @name CF_DefaultLangSelect / / . . .
Введение в модели и алгоритмы машинного обучения
InfoMaster 12.01.2025
Машинное обучение представляет собой одну из наиболее динамично развивающихся областей искусственного интеллекта, которая фокусируется на разработке алгоритмов и методов, позволяющих компьютерам. . .
Как на Python создать нейросеть для решения задач
InfoMaster 12.01.2025
В контексте стремительного развития современных технологий особое внимание уделяется таким инструментам, как нейросети. Эти структуры, вдохновленные биологическими нейронными сетями, используются для. . .
Как создать нейросеть для генерации картинок на Python
InfoMaster 12.01.2025
Генерация изображений с помощью искусственных нейронных сетей стала одним из наиболее захватывающих направлений в области компьютерного зрения и машинного обучения. В этой статье мы рассмотрим. . .
Создание нейросети для генерации текста на Python
InfoMaster 12.01.2025
Нейросети, или искусственные нейронные сети, представляют собой модели машинного обучения, вдохновленные работой человеческого мозга. Они состоят из множества взаимосвязанных узлов, или "нейронов",. . .
Как создать нейросеть распознавания изображений на Python
InfoMaster 12.01.2025
Введение в распознавание изображений с помощью нейросетей Распознавание изображений с помощью нейронных сетей стало одним из самых впечатляющих достижений в области искусственного интеллекта. Эта. . .
Основы искуственного интеллекта
InfoMaster 12.01.2025
Искусственный интеллект (ИИ) представляет собой одну из наиболее динамично развивающихся областей современной науки и технологий. В широком смысле под искусственным интеллектом понимается способность. . .
Python и нейросети
InfoMaster 12.01.2025
Искусственные нейронные сети стали неотъемлемой частью современных технологий, революционизировав множество областей - от медицинской диагностики до автономных транспортных средств. Python, благодаря. . .
Python в машинном обучении
InfoMaster 12.01.2025
Python стал неотъемлемой частью современного машинного обучения, завоевав позицию ведущего языка программирования в этой области. Его популярность обусловлена несколькими ключевыми факторами, которые. . .
Создание UI на Python с TKinter
InfoMaster 12.01.2025
TKinter — это одна из наиболее популярных библиотек для создания графических интерфейсов пользователей (GUI) в языке программирования Python. TKinter входит в стандартную библиотеку Python, что. . .
HTML5 в разработке мобильных приложений
InfoMaster 12.01.2025
Введение: Обзор роли HTML5 в мобильной разработке В современном мире мобильных технологий HTML5 стал ключевым инструментом для разработки кроссплатформенных приложений. Эта технология произвела. . .
Как создавать приложения для iOS/iPhone
InfoMaster 12.01.2025
Введение в разработку iOS-приложений Разработка приложений для iOS открывает огромные возможности в мире мобильных технологий. С каждым годом количество пользователей iPhone и iPad растет,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru