Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.78/9: Рейтинг темы: голосов - 9, средняя оценка - 4.78
0 / 0 / 0
Регистрация: 04.10.2009
Сообщений: 15

В массиве поменять местами парные числа

04.10.2009, 21:48. Показов 1923. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Подскажите, пожалуйста, в чем моя ошибка!
Нужно в массиве поменять местами парные числа
вот код:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
int a[10],i,k,j;
for(i=0;i<10;i++)
{a[i]=StrToInt(StringGrid1->Cells[i][0]);}
 for(i=0;i<10;i++)
 {
 for(j=9;j>i;j--)
 {
 for(m=0;
  { if(a[i]%2==0)
 {k=a[j-1];
 a[j-1]=a[j];
 a[j]=k;}}}
for(i=0;i<10;i++){
StringGrid2->Cells[i][0]=IntToStr(a[i]);
}}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.10.2009, 21:48
Ответы с готовыми решениями:

В заданном массиве необходимо поменять местами имеющиеся в единственном экземпляре числа 5 и 15
В заданном массиве необходимо поменять местами имеющиеся в единственном экземпляре числа 5 и 15. Дополнительную переменную для обмена...

В массиве поменять местами числа 5 и 15; найти сумму диагональных элементов в 2-мерном массиве.
Тема: Использование вложенных циклов и ветвлений при обработке массивов, обработка матриц....

Поменять местами положительные и отрицательные числа в массиве
Помогите пожалуйста, с клавиатуры вводится массив из 10 чисел(положительных и отрицательных), переместить отрицательные в начало массива, а...

7
Маэстро
Вирусоборец
 Аватар для Maestro
1244 / 365 / 40
Регистрация: 06.09.2009
Сообщений: 798
05.10.2009, 11:44
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

UnderSun, Пока что ошибка в строках 8 и 9. Условие цикла правильное? Нехватает круглой закрывающей скобки в цикле for

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
   int a[10], i, k, j;
 
   for(i = 0; i < 10; i++){
     a[i] = StrToInt(StringGrid1->Cells[i][0]);
    }
     for(i = 0; i < 10; i++){
       for(j = 9; j > i; j--){
         for(m=0;    // Цикл правилен? 
  {         // Скобка правильна?
         if(a[i] % 2 == 0){
           k = a[j - 1];
           a[j - 1] = a[j];
           a[j] = k;
          }
       } 
     }
   for(i = 0; i < 10; i++){
     StringGrid2->Cells[i][0] = IntToStr(a[i]);
    }
 }
0
0 / 0 / 0
Регистрация: 04.10.2009
Сообщений: 15
05.10.2009, 20:57  [ТС]
сорри, вообще без 8-ой строки
0
Маэстро
Вирусоборец
 Аватар для Maestro
1244 / 365 / 40
Регистрация: 06.09.2009
Сообщений: 798
06.10.2009, 15:29
UnderSun, Напишите пожалуйста в строку:

1. Значения исходного массива.
2. Значения результирующего массива.
0
0 / 0 / 0
Регистрация: 04.10.2009
Сообщений: 15
06.10.2009, 16:48  [ТС]
Maestrino:
К примеру нужно так:
A={1,-4,6,3,9,10,-5,2,7,11}
получить:
A={1,2,10,3,9,6,-5,-4,7,11}
т.е. поменять местами в массиве четные числа, а нечетные - не трогать
0
Маэстро
Вирусоборец
 Аватар для Maestro
1244 / 365 / 40
Регистрация: 06.09.2009
Сообщений: 798
06.10.2009, 17:27
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

UnderSun, В вашем коде происходит перестановка несколько раз из-за многих количеств проверок. Теперь, если одно число чётное сначала, то с другого конца должно быть тоже чётное. Вроде должно работать. Хотя у меня тоже переставляет по нескольку раз, нужен один прогон или перестановка "до упора" ?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
...
   const int size = 10; // Размер массива
   int a[size] = { 1, -4, 6, 3, 9, 10, -5, 2, 7, 11 };
   int i, k, j;   
 
   for(i = 0; i < size; i++){
      if(a[i] % 2 == 0){
         for(j = size-1; j > i; j--){
            if(a[j] % 2 == 0){
//               cout<<"a["<<i<<"]"<<a[i]<<" = "<<"a["<<j<<"]"<<a[j]<<endl;  // Отлаживал на консоли...
               k = a[i];
               a[i] = a[j];
               a[j] = k;
             }
         }
      }
   }
...
0
0 / 0 / 0
Регистрация: 04.10.2009
Сообщений: 15
06.10.2009, 18:14  [ТС]
Maestrino, большое спасибо, у меня работает!
0
Маэстро
Вирусоборец
 Аватар для Maestro
1244 / 365 / 40
Регистрация: 06.09.2009
Сообщений: 798
06.10.2009, 18:18
UnderSun, Перепроверьте перестановки, точно работает? А то я что-то уже сам сомневаюсь.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.10.2009, 18:18
Помогаю со студенческими работами здесь

Не могу поменять местами кратные числа в одномерном массиве программа ругается
#include &lt;stdio.h&gt; #include &lt;math.h&gt; void main() { int i,temp;int *k_5; int *k_3; float a; for (i = 0; i&lt;7; i++) { ...

Найти в массиве два числа, являющимися перевертышами друг друга и поменять их местами.
дано массив с элементами а1, а2, ... {a}_{n}. найдите две целых чисел что бы они поменяли местами. Например 21 = 12 Решение в Delphi 7

Найти парные числа больше 5 в массиве
Помогите решить задание с помощью С# WPF нужно одномерный массив из 10-ти целых чисел заполнить с клавиатуры, определить сумму тех чисел,...

Поменять в массиве местами местами первое и последние значение, второе и предпоследнее
Дан одномерный массив.Поменять местами местами первое и последние значение ,второе и предпоследнем.

Как в одномерном массиве поменять местами четные и нечетные элементы местами
Как в обычном одномерном массиве поменять местами четные и нечетные элементы местами, без array


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru