Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.59/103: Рейтинг темы: голосов - 103, средняя оценка - 4.59
4 / 4 / 1
Регистрация: 17.10.2009
Сообщений: 21

Поменять местами первую и вторую половину массива.

08.03.2010, 17:14. Показов 19492. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите решить задачки!!!
1) Дан массив размера n. Поменять местами первую и вторую половину массива.
2)Дана матрица размера mхn.Найти локальный минимум и вывести их координаты.Если таких элементов нет,вывести соответствующее сообщение.

Заранее спасибо!!!!!!!!!!!!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
08.03.2010, 17:14
Ответы с готовыми решениями:

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

Поменять местами первую и вторую половину строки, причем так
Помогите решить пожалуйста задачу! Дана строка. Поменять местами первую и вторую половину строки, причем так, чтобы в первой половине...

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

7
 Аватар для cibertronic
257 / 144 / 18
Регистрация: 27.12.2009
Сообщений: 909
08.03.2010, 17:31
для первой задачи не совсем ясно....массив одномерный или матрица?
0
4 / 4 / 1
Регистрация: 17.10.2009
Сообщений: 21
08.03.2010, 17:33  [ТС]
одномерный массив
0
Day
 Аватар для Day
1180 / 990 / 83
Регистрация: 29.10.2009
Сообщений: 1,385
08.03.2010, 17:36
1.
C++
1
2
3
4
5
  for(i=0; i<n/2;i++) {
     t = a[i];
     a[i] = a[n-1-i];
     a[n-1-i] = t;
  }
Т.к. тип массива мне неизвестен, декларации сделаешь сама
2.Если я правильно понял - локальный минимум - это когда меньше всех окружающих?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
   k = 0;
   for(i=0; i<n; i++) {
     for(j=0; j<m; j++) {
        for(ii=i-1; ii<=i+1; ii++) {
            if (ii<0 || ii>=n) continue;  // Не рассматриваем клетки, вылезающие за край
            for(jj=j-1; jj<=j+1; jj++) {
               if (jj<0 || jj>=m) continue;
               if (a[i][j] >= a[ii][jj]) break; // Не минимум
            }
             if (jj<j+1) break;
        }
         if (i<ii+1) continue; // т.к. из цикла вылетели раньше - a[i][j] - не минимум
         cout "Loc.Min = " << a[i][j] << "i=" << i << "j=" << j << endl;
         k++;
     }
   }
   if (k==0) cout << "Not Loc.Min" << endl;
С праздником!
1
Эксперт С++
 Аватар для Nameless One
5828 / 3479 / 358
Регистрация: 08.02.2010
Сообщений: 7,448
08.03.2010, 17:39
Цитата Сообщение от Лена18 Посмотреть сообщение
1) Дан массив размера n. Поменять местами первую и вторую половину массива.
Работает для массивов с четным и нечетным числом элементов (для нечетного числа элементов первая половина на единицу больше второй):
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <iostream>
 
int main()
{
    const size_t n=7;
    const size_t mid=n/2;
    int arr[n]={1, 2, 3, 4, 5, 6, 7};
    int temp[n-mid];
    std::copy(arr, arr+n-mid, temp);
    std::copy(arr+n-mid, arr+n, arr);
    std::copy(temp, temp+n-mid, arr+mid);
 
    for(size_t i=0; i<n; ++i, std::cout << std::endl)
        std::cout << arr[i];
    system("pause");
}
1
 Аватар для cibertronic
257 / 144 / 18
Регистрация: 27.12.2009
Сообщений: 909
08.03.2010, 17:48
блин )) пока гостей провожал, нписали уже)) ну да ладн)
0
Day
 Аватар для Day
1180 / 990 / 83
Регистрация: 29.10.2009
Сообщений: 1,385
08.03.2010, 18:07
Лена18, Наверное, я не совсем правильно понял условие 1. Видимо, надо просто поменять,
а я симметрично отразил. Тогда cibertronic прав. Но и тут можно было обойтись без введения
промежуточного массива temp...
Все-таки правила хорошего тона требуют не вводить без нужды промежуточных массивов
C++
1
2
3
4
5
6
7
8
  m = n/2;
  if (n%2) k = m+1;
  else       k = m;
  for(i=0; i<m; i++) {
     t = a[i];
     a[i] = a[k+i];
     a[k+i] = t;
  }
Пр нечетном n средний элемент остается на месте
0
Эксперт С++
 Аватар для Nameless One
5828 / 3479 / 358
Регистрация: 08.02.2010
Сообщений: 7,448
08.03.2010, 18:14
Цитата Сообщение от Day Посмотреть сообщение
Все-таки правила хорошего тона требуют не вводить без нужды промежуточных массивов
Согласен, это просто демонстрация алгоритма стандартной библиотеки шаблонов
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.03.2010, 18:14
Помогаю со студенческими работами здесь

Удалить первую половину элементов из динамического массива, вторую половину поставить на место первой
удалить первую половину елементов из динамического массива , а вторую половину вставить на место первой.

Поменять местами первую и вторую половины массива
Дан массив а, состоящий из 10 элементов. Поменять местами первую и вторую его половины

Отсортировать по возрастанию первую половину массива, и по убыванию вторую половину массива
Напишите программу, которая сортирует по возрастанию первую половину массива и по убыванию вторую половину массива. Каждый элемент должен...

Одномерный массив: Поменять местами первую и вторую половины массива
Дан массив размера N (N — четное число). Поменять местами первую и вторую половины массива.

Дан массив. Поменять местами его первую и вторую половины массива
Дан массив. Поменять местами его первую и вторую половины массива... Пожалуйста решение очень легким методом) чтобы я понял код, т.к...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru