Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
aquarius-a
0 / 0 / 0
Регистрация: 16.04.2011
Сообщений: 48
#1

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

17.05.2011, 22:27. Просмотров 735. Ответов 7
Метки нет (Все метки)

задача: дан массив и число x. переставить числа в массиве таким образом, чтобы сначала массива шли числа, меньшие x, затем равные x, в конце - большие x.
если не затруднит подскажите алгоритм решения этой задачи (а можно и код)
заранее спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.05.2011, 22:27
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Перестановка чисел в массиве (C++):

Перестановка чисел в массиве в обратном порядке. - C++
Прошу помогите!!! Надо решить 2 задачи по С++ !! Срочно!!! 1)написать функцию reverse. Параметр: массив из 100 чисел....

Перестановка в массиве - C++
Дана целочисленная прямоугольная матрица. 1. Определить количество столбцов, не содержащих ни одного нулевого элемента 2....

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

Перестановка строк в массиве - C++
Здравствуйте, не могу никак сообразить, как сделать свою задачу: Необходимо переставить строки в матрице. Пример: Исходная матрица: ...

Перестановка строк в двухмерном массиве - C++
Подскажите пожалуйста функцию осуществляющую перестановку строк в двухмерном массиве 7*7 следующим образом: первую и последнюю,вторую и...

перестановка четных элементов в массиве на место нечетных и наоборот - C++
в массиве х заменить элементы таким образом, чтобы элементы с четными номерами встали на место нечетных и наоборот, и занести их в массив...

7
MILAN
886 / 780 / 86
Регистрация: 21.02.2009
Сообщений: 1,722
17.05.2011, 22:44 #2
aquarius-a, если я вас правильно понял, вам нужно отсортировать массив по возростанию?
0
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}
0
-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;
}
0
kravam
быдлокодер
1701 / 888 / 45
Регистрация: 04.06.2008
Сообщений: 5,498
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;
}
0
asics
Freelance
Эксперт С++
2848 / 1783 / 144
Регистрация: 09.09.2010
Сообщений: 3,841
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;
}
0
aquarius-a
0 / 0 / 0
Регистрация: 16.04.2011
Сообщений: 48
18.05.2011, 01:05  [ТС] #7
всем большое спасибо
0
ds102061
2 / 2 / 2
Регистрация: 13.10.2010
Сообщений: 144
02.06.2011, 20:45 #8
а как если числа меньшие 7 оставить на самих же местах, а большие упорядочить по возростанию
0
02.06.2011, 20:45
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.06.2011, 20:45
Привет! Вот еще темы с ответами:

Перестановка чисел - C++
Для заданного n получить все возможные перестановки чисел: 1, 2, …, n. Подскажите плиз как сделать.

Перестановка чисел - C++
Дано двузначное число. Вывести число, полученное при перестановке цифр исходного числа.

Перестановка чисел(функция) - C++
Даны 4 числа. Организуйте перестановку данных чисел в обратном порядке. Перестановку двух чисел организуйте в виде отдельной функции....

Проверить, есть ли в массиве А [n] числа В и С и определить, какое из чисел встречается в массиве чаще - C++
1. Проверить, есть ли в массиве А числа В и С и определить, какое из чисел встречается в массиве чаще.


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru