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

перестановка чисел в массиве - C++

Восстановить пароль Регистрация
 
aquarius-a
0 / 0 / 0
Регистрация: 16.04.2011
Сообщений: 48
17.05.2011, 22:27     перестановка чисел в массиве #1
задача: дан массив и число x. переставить числа в массиве таким образом, чтобы сначала массива шли числа, меньшие x, затем равные x, в конце - большие x.
если не затруднит подскажите алгоритм решения этой задачи (а можно и код)
заранее спасибо.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
MILAN
 Аватар для MILAN
883 / 777 / 86
Регистрация: 21.02.2009
Сообщений: 1,722
17.05.2011, 22:44     перестановка чисел в массиве #2
aquarius-a, если я вас правильно понял, вам нужно отсортировать массив по возростанию?
aquarius-a
0 / 0 / 0
Регистрация: 16.04.2011
Сообщений: 48
17.05.2011, 23:12  [ТС]     перестановка чисел в массиве #3
не совсем, просто переставить в исходном неупорядоченном массиве числа по указанному принципу

Добавлено через 2 минуты
например массив {5,7,1,5,3,9,7,2,2,4,10}, x=7
результат должен быть таким: {5,1,5,3,2,2,4,7,7,9,10}
-comrade-
355 / 356 / 42
Регистрация: 11.06.2010
Сообщений: 703
18.05.2011, 00:36     перестановка чисел в массиве #4
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <iostream>
 
using namespace std;
 
int main()
{
    int i,n,x;
    cout<<"  N=";
    cin>>n;
    int *a=new int [n];
    cout<<"  Enter elements: ";
    for(i=0;i<n;i++) cin>>a[i];
    cout<<"  X=";
    cin>>x;
    cout<<"  New array: ";
    for(i=0;i<n;i++) if(a[i]<x)  cout<<a[i]<<" ";
    for(i=0;i<n;i++) if(a[i]==x) cout<<a[i]<<" ";
    for(i=0;i<n;i++) if(a[i]>x)  cout<<a[i]<<" ";
    delete [] a;
    cout<<endl;
    system("pause");
    return 1;
}
kravam
быдлокодер
 Аватар для kravam
1512 / 872 / 44
Регистрация: 04.06.2008
Сообщений: 5,271
18.05.2011, 00:49     перестановка чисел в массиве #5
Не славы ради но разминки для
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
34
35
36
37
#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>
#define size 20
using namespace std;
 
int x;
bool IsOdd (int i) { return (i>=x); }
bool IsOdd_ (int i) { return (i<=x); }
 
 
int main () {
 srand (time(0));
 int arr [size];
 for (int i= 0; i< size; i++)
  printf ("%d ", arr [i]= rand()%100);  
 printf ("\n");  
 
 x= rand()%100;
 printf ("x= %d\n");
 vector<int> v_0(arr, &arr[size]);
 vector<int> v_1= v_0;
 
 remove_if (v_0.begin(), v_0.end(), IsOdd);
 
 vector<int>::iterator new_end; 
 new_end= remove_if (v_1.begin(), v_1.end(), IsOdd_);
 
 v_0.insert(v_0.end()-(new_end- v_1.begin()), v_1.begin(), new_end);
 v_0.resize(size);
 copy(v_0.begin(), v_0.end(),ostream_iterator<int>(cout, " ")); 
 printf ("\n");  
 
 getchar();
 return 0;
}
asics
Freelance
Эксперт C++
 Аватар для asics
2838 / 1775 / 144
Регистрация: 09.09.2010
Сообщений: 3,842
18.05.2011, 01:00     перестановка чисел в массиве #6
Еще вариант:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <iostream>
#include <algorithm>
#include <iterator>
#include <boost/lambda/lambda.hpp>
 
namespace b_l = boost::lambda;
 
int main(){
  int a[] = {5, 7, 1, 5, 3, 9, 7, 2, 2, 4, 10}, s = sizeof(a) / sizeof(int), x = 7;
  std::sort(a, a + s, b_l::_1 < x || b_l::_2 >= x && b_l::_1 == x || b_l::_2 > x);
  std::copy(a, a + s, std::ostream_iterator<int>(std::cout, " "));
  return 0;
}
aquarius-a
0 / 0 / 0
Регистрация: 16.04.2011
Сообщений: 48
18.05.2011, 01:05  [ТС]     перестановка чисел в массиве #7
всем большое спасибо
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.06.2011, 20:45     перестановка чисел в массиве
Еще ссылки по теме:

C++ Перестановка строк в двухмерном массиве
Перестановка чисел C++
C++ Перестановка чисел(функция)

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

Или воспользуйтесь поиском по форуму:
ds102061
 Аватар для ds102061
2 / 2 / 2
Регистрация: 13.10.2010
Сообщений: 144
02.06.2011, 20:45     перестановка чисел в массиве #8
а как если числа меньшие 7 оставить на самих же местах, а большие упорядочить по возростанию
Yandex
Объявления
02.06.2011, 20:45     перестановка чисел в массиве
Ответ Создать тему
Опции темы

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