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

Перестановка "-"элементов в массиве в начало

30.09.2014, 21:03. Показов 2114. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дан массив M[a], нужно переместить первые k элементов этого массива в начало.
То есть: было - -1 2 -3 -4 5 6 7
при условии, что k=3 то,
стало -1 -3 -4 2 5 7.
при условии, что k=2, то
стало -1 -3 2 -4 5 6 7.
Знаю, что нужно(или можно) приравнивать каждый элемент массива к 0, и если он меньше то - в начало, если нет - то на место. А как осуществить это программно (в коде) (да и ещё чтобы только первые k) - не пойму.
Помогите, пожалуйста. Хотелось бы понять как это делается.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
30.09.2014, 21:03
Ответы с готовыми решениями:

Перестановка элементов в матрице: отрицательные поставить в начало, а положительные после них
Никак не могу сообразить алгоритм задачи: Есть матрица(размерность любая),с неё нужно сделать вектор Х. Компоненты вектора X - среднее...

Перестановка элементов в массиве
Помогите с задачкой: Дан размер массива =100 Диапазон значений от -50 до +50 Во всех последовательностях положительных чисел изменить...

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

8
 Аватар для Новичок
1682 / 1098 / 489
Регистрация: 17.07.2012
Сообщений: 5,361
01.10.2014, 19:34
Цитата Сообщение от Magestian Посмотреть сообщение
Дан массив M[a], нужно переместить первые k элементов этого массива в начало.
Первые k отрицательных элементов?
0
1 / 1 / 0
Регистрация: 25.09.2014
Сообщений: 125
01.10.2014, 19:35  [ТС]
Да, первые k отрицательных.
0
 Аватар для Новичок
1682 / 1098 / 489
Регистрация: 17.07.2012
Сообщений: 5,361
01.10.2014, 19:50
Цитата Сообщение от Magestian Посмотреть сообщение
-1 -3 -4 2 5 7.
А куда 6 делось?

Добавлено через 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
var m:array[1..100] of Integer;
i,n,k,a,t:Integer;
begin
Write('a=');
Readln(a);
for i:=1 to a do 
 begin
  Write('M[',i,']=');
  Readln(m[i]);
 end;
Writeln('Исходный массив:');
for i:=1 to a do Write(m[i],' ');
Writeln;
Write('k=');
Readln(k);
n:=0;
for i:=1 to a do  
 begin
  if m[i]<0 then
   begin
    inc(n);
    t:=m[i];
    m[i]:=m[n];
    m[n]:=t;
   end;
  if n=k then Break;
 end;
Writeln('Полученный массив:');
for i:=1 to a do Write(m[i],' ');
Readln;
end.
1
1 / 1 / 0
Регистрация: 25.09.2014
Сообщений: 125
01.10.2014, 19:56  [ТС]
Спасибо, теперь всё понятно Сейчас протестирую. Задают в техникуме. (дополнительно)
0
 Аватар для Новичок
1682 / 1098 / 489
Регистрация: 17.07.2012
Сообщений: 5,361
01.10.2014, 20:17
Лучший ответ Сообщение было отмечено Magestian как решение

Решение

Кажется, я не так понял задание. Вот так правильно.
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
var m:array[1..100] of Integer;
i,j,n,k,a,t:Integer;
begin
Write('a=');
Readln(a);
for i:=1 to a do 
 begin
  Write('M[',i,']=');
  Readln(m[i]);
 end;
Writeln('Исходный массив:');
for i:=1 to a do Write(m[i],' ');
Writeln;
Write('k=');
Readln(k);
n:=0;
for i:=1 to a do  
 begin
  if m[i]<0 then
   begin
    inc(n);
    t:=m[i];
     for j:=i downto n+1 do m[j]:=m[j-1];
    m[n]:=t;
   end;
  if n=k then Break;
 end;
Writeln('Полученный массив:');
for i:=1 to a do Write(m[i],' ');
Readln;
end.
1
1 / 1 / 0
Регистрация: 25.09.2014
Сообщений: 125
01.10.2014, 20:28  [ТС]
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
Program akr;
const a=10;
var m:array[1..a] of integer;
      i,n,k,t:integer;
 
Begin
for i:=1 to a do
 Begin
 write('Enter a value in the array M[',i,']');
 readln(m[i]);
 End;
writeln('Initial array:  ');
for i:=1 to a do write(m[i],'  ');
write('k=');
read(k);
n:=0;
for i:=1 to a do
 Begin
 if m[i]<0 then
  Begin
  inc(n);
  t:=m[i];
  m[i]:=m[n];
  m[n]:=t;
  End;
 if n=k then Break;
 End;
writeln('Transposed array: ');
for i:=1 to a do write(m[i],'  ');
readln;
End.
Немного под себя переделал. Всё работает отлично

Добавлено через 1 минуту
Нет, нет. Первый вариант больше подходит.
0
 Аватар для Новичок
1682 / 1098 / 489
Регистрация: 17.07.2012
Сообщений: 5,361
01.10.2014, 20:31
Дело в том, что все-таки нужно в задании. Вот смотрите.
Допустим есть массив
-1 2 3 -3 4 5
k=2
Первая моя прога выведет,
-1 -3 3 2 4 5
А вторая(вроде бы так и надо) выводит,
-1 -3 2 3 4 5
Т.е порядок элементов сохраняет.
1
1 / 1 / 0
Регистрация: 25.09.2014
Сообщений: 125
01.10.2014, 20:40  [ТС]
Хотя, да. Соглашусь со вторым вариантом. Он больше подходит.
Просто внёс в прошлый переделанный код новые части из другого.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
01.10.2014, 20:40
Помогаю со студенческими работами здесь

Перестановка элементов в массиве
В массиве a..a целых чисел переставить элементы так что бы четные числа шли перед нечетными не меняя взаимный порядок внутри каждой из...

Перестановка элементов в массиве
Необходимо поменять местами в массиве найденные min и min2. Помогите пожалуйста #include &quot;stdafx.h&quot; #include...

Перестановка элементов в массиве
Нужно переставить элементы массива в обратном порядке. в моём коде ошибка, но я не понял где : #include &lt;iostream&gt; #include...

Перестановка элементов в массиве
Задача: Переставить в массиве первый элемент и максимальный. Просьба написать процедуру нахождения максимального элемента и его...

перестановка элементов в массиве
Задание: нужно переставить каждые четыре элемента в одномерном динамическом массиве с помощью указателей (1,2, 3,4 ↔ 5,6,7,8; 9,10,11,12 ↔...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
Контроль уникальности заводского номера - вариант №2
Maks 24.03.2026
В отличие от предыдущего варианта добавлено прерывание циклов, также добавлены новые переменные для сохранения контекста ошибки перед прерыванием цикла: Процедура ПередЗаписью(Отказ, РежимЗаписи,. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
Контроль уникальности заводского номера - вариант №1
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью в КА2. Данные берутся из регистра сведений, по которому настроено. . .
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа в КА2. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru