Форум программистов, компьютерный форум CyberForum.ru

Изменить массив - C++

Восстановить пароль Регистрация
 
J_Max
Заблокирован
11.04.2010, 21:46     Изменить массив #1
Здравствуйте уважаемые форумчане.

Прошу помощи в решении следующей задачи:
Дан массив размером n;

Написать функцию шаблон, которая меняет расположение элементов следующим образом,
сначала будут идти отрицательные а потом все остальные.

В функциях я разбираюсь алгоритм придумать не могу.
Если есть время помогите как нибудь.
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.04.2010, 21:46     Изменить массив
Посмотрите здесь:

C++ Как изменить многомерный массив?
Массив: элементы не главной диагонали изменить на противоположные знаки. C++
Изменить порядок следования элементов в массиве на обратный, используя массив указателей C++
C++ Массив: каким образом можно изменить размер многомерного массива
Одномерный массив, изменить программу C++
Прочитать массив из файла, изменить, вывести в другой файл C++
C++ Что нужно изменить, чтобы был динамический массив?
Дан динамический одномерный массив размера N, изменить размер массива до M C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Genius Ignat
1233 / 771 / 44
Регистрация: 16.09.2009
Сообщений: 2,014
11.04.2010, 21:54     Изменить массив #2
Вот сырец: кое что на затравку.
C++
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
#include <iostream>
template<class T>
long transform(T *m ,  int size); 
int main(){
const int size = 10;
int massive[size] = {1,2,3,4,5,-6,-7,-8,9,10};
transform(massive,size);
for ( int i = 0 ; i < size ; i++ )std::cout<<massive[i]<<' '; 
std::cout<<'\n';
 
return 0;
}
 
template<class T>
long transform(T *m , int size){
 
int save_p = -1;    
  for ( int i =  0 ; i < size ; i++ )              
               for( int j = save_p+1; j < size ; j++ ){
                   if(m[j]<0){
                       T tmp1 = m[i];   
                   T tmp2 = m[j];
                                   m[i]=tmp2;
                   m[j]=tmp1;
                   save_p = j;
                   j = size;
                   }
        
        }
 
 
return 0;
}
fasked
Эксперт C++
 Аватар для fasked
4924 / 2504 / 180
Регистрация: 07.10.2009
Сообщений: 4,306
Записей в блоге: 1
12.04.2010, 03:36     Изменить массив #3
Сообщение было отмечено автором темы, экспертом или модератором как ответ
если порядок следования отрицательных элементов не важен, то можно вот так еще:
C++
1
2
3
4
    for(int i = 0; i < size; i++)
        for(int j = i; j > 0; j--)
            if(a[j] < 0)
                std::swap(a[j], a[j-1]);
Yandex
Объявления
12.04.2010, 03:36     Изменить массив
Ответ Создать тему
Опции темы

Текущее время: 13:47. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru