17 / 17 / 0
Регистрация: 13.09.2009
Сообщений: 140
1

Сортировка и поиск

11.12.2009, 19:00. Показов 1467. Ответов 19
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Доброго всем времени суток, прошу помочь Вас решить мне простенькую задачку, у меня она чёт то не получается. Вот её условие: "Найти в отсортированном в порядке возрастания элементов массив. Вставить в этот массив новый элемент, не нарушая сортировки.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
11.12.2009, 19:00
Ответы с готовыми решениями:

Сортировка и поиск
Сгенерировать массив (массив объявлять динамически) и вывести его на экран (Использовать при этом...

Сортировка и поиск...
Создать текстовый файл который состоят из 16000 целых чисел. data1.txt - числа в диапазоне 0 -...

Поиск и сортировка
Дан массив из 20 целых чисел со значениями от 1 до 20. Необходимо: • написать функцию,...

сортировка и поиск
надо по сортировать числа 12 22 15 55 11 21 12 31 13 51 55 15 методом пузырька! в отсортированном...

19
17 / 17 / 0
Регистрация: 13.09.2009
Сообщений: 140
12.12.2009, 09:06  [ТС] 2
Я считаю, что необходимо отсортировать массив чисел за возрастанием, и вставить в него новое число так, что бы оно тоже было отсортировано в этом массиве. Только я пока не понимаю как это сделать.
0
Эксперт С++
7175 / 3234 / 81
Регистрация: 17.06.2009
Сообщений: 14,164
12.12.2009, 19:56 3
1) Найти место куда вставить.
2) Сдвинуть хвост массива на 1 позицию
3) Записать новый элемент
0
17 / 17 / 0
Регистрация: 13.09.2009
Сообщений: 140
12.12.2009, 20:23  [ТС] 4
Я это понимаю, и спрашиваю как?
0
║XLR8║
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,361
Записей в блоге: 5
12.12.2009, 20:39 5
C++
1
2
for (int i = n; i > pos; --i) //pos - позиция куда вставлять, n - количество элем масива
    a[n] = a[n-1]
0
17 / 17 / 0
Регистрация: 13.09.2009
Сообщений: 140
12.12.2009, 20:45  [ТС] 6
можно чуть побольше объяснить. чёт не выходит(
0
17 / 17 / 0
Регистрация: 13.09.2009
Сообщений: 140
13.12.2009, 22:36  [ТС] 7
отзовитесь. кто-то!!
0
║XLR8║
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,361
Записей в блоге: 5
13.12.2009, 23:53 8
покажите что у вас не выходит
0
17 / 17 / 0
Регистрация: 13.09.2009
Сообщений: 140
15.12.2009, 11:59  [ТС] 9
Вот что-то написал, а теперь подскажите, как сделать, что б выводить массив чисел в порядке возрастания
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>
#include<conio.h>
#include<stdio.h>
using namespace std;
int main ()
{
     int  n,i;
     double a[100];
 
     
cout<<endl;
cout<<" Vedite i  ";
cin>>n;
cout<<endl;
 for (i=0;i<n;i++) {cout<<"vediite a("<<i<<") ";cin>>a[i];
 a[i]=a[i+1];
 
 }
cout<<endl<<endl;
    
system("Pause");
return 0;
}
0
17 / 17 / 0
Регистрация: 13.09.2009
Сообщений: 140
15.12.2009, 20:42  [ТС] 10
Скажите чё не так!!
0
║XLR8║
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,361
Записей в блоге: 5
15.12.2009, 21:13 11
C++
1
2
3
4
5
void swap(int &a, int &b) {a += b; b = a - b;}
//int k - надо вставить в возр. послед.
a[n+1] = k;
for (int i = n+1; i > 0; --i)
   (a[i-1] > a[i]) ? swap(a[i],a[i-1]) : break;
0
14 / 14 / 3
Регистрация: 19.09.2009
Сообщений: 289
15.12.2009, 21:13 12
ты элементы то сдвигай, сделай еще один цикл, но что-бы он шел с конца и было так типа, i++=i;
0
║XLR8║
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,361
Записей в блоге: 5
15.12.2009, 21:24 13
кто-то знает, так написать прокатит?
C++
1
for (int i = n+1; i > 0; --i, (a[i-1] > a[i]) ? swap(a[i],a[i-1]) : break)
0
17 / 17 / 0
Регистрация: 13.09.2009
Сообщений: 140
15.12.2009, 21:40  [ТС] 14
outoftime,
Цитата Сообщение от outoftime Посмотреть сообщение
swap
- У меня не понимает эту функцию, не компилирует, я уже раньше это пробовал.


BOR1K,
Цитата Сообщение от BOR1K Посмотреть сообщение
i++=i;
-я не понял, что ты хочешь этим сказать,
Объясни пожалуйста поподробнее, что ты хотел этим сказать.

Добавлено через 15 минут
а как вывести на экран отсортираванный массив чисел, и массив чисел из вставленным числом
0
0 / 0 / 0
Регистрация: 15.12.2009
Сообщений: 3
15.12.2009, 22:32 15
Помогите пожалуйста. Надо сравнить время сортировки массива. Быстрая, пирамидальная и пузарьковая
0
║XLR8║
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,361
Записей в блоге: 5
15.12.2009, 22:47 16
да, она корявая, вот:
C++
1
void swap(int &a, int &b){b += a; a = b - a; b -= a;}
учтите, что в вашем случае это указатель не на инт а на масив интов, можете, к примеру, передавать только индексы элементов, которые нужно поменять..
0
0 / 0 / 0
Регистрация: 15.12.2009
Сообщений: 3
16.12.2009, 00:51 17
ой, сори, я не в ту тему написал..мне паскаль нужен
0
17 / 17 / 0
Регистрация: 13.09.2009
Сообщений: 140
16.12.2009, 11:32  [ТС] 18
Я раньше спрашивал, и сейчас спрашиваю, как вывести на экран отсортированный массив чисел из вставленным числом?
0
Эксперт JavaЭксперт С++
8384 / 3616 / 419
Регистрация: 03.07.2009
Сообщений: 10,709
16.12.2009, 14:52 19
Что это?
C++
1
2
3
4
for (i=0;i<n;i++) {cout<<"vediite a("<<i<<") ";cin>>a[i];
 a[i]=a[i+1];
 
 }
Ввод выглядит так
C++
1
2
for (i=0;i<n;i++) 
    cout<<"vediite a("<<i<<") = ", cin>>a[i];
0
17 / 17 / 0
Регистрация: 13.09.2009
Сообщений: 140
16.12.2009, 21:24  [ТС] 20
Да то забыл удалить, перед тем как сюда скопировать, лучше пусть мне кто-то всё-таки поможет её решить(я уже в ней запутался, простая фигня, а в голову не идёт)))))
0
16.12.2009, 21:24
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
16.12.2009, 21:24
Помогаю со студенческими работами здесь

Поиск и сортировка
Задача. Дан массив из 20 целых чисел со значениями от 1 до 20. Необходимо: • написать функцию,...

Поиск, Сортировка по Вектору в с++
Не могу разобраться как обратится к элементу класса например name. в векторе groupArray. Из за...

stl сортировка,поиск
Как правильно сортировать Multiset&lt;char&gt; A Queue&lt;char&gt; B Напишите плз для каждого по 2...

Поиск и сортировка в массиве структур
Доброго времени суток! Нужна помощь! Уменьшить на 10% стоимость билетов тех рейсов, время в...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru