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

С++... сортировка по модулю.

10.12.2010, 01:09. Показов 4448. Ответов 3
Метки нет (Все метки)

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

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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
#include <iostream>
#include <cmath>
using namespace std;
//Прототип функции для ввода вектора
void inputv(double x[],int n);
//Прототип функции для вывода вектора
void outputv(double x[],int n);
//Прототип функции для вычисления индекса минимального элемента
void min(double x[],int n,int&m);
//Прототип функции для вычисления суммы между первым и вторым отрицательными элементами
void summ(double x[],int n, double&S);
//Прототип функци для сортировки
void sort(double x[],int n);
//Главная функция
void main()
{//Руссификация
    setlocale(LC_ALL,"Russian");
//Объявляем вектор и переменные
    double a[5],S;
    int m,j,i;
//Ввод вектора
    cout<<"\n Ввести через пробел координаты вектора \n";
    inputv(a,5);
 
//Вычисления индекса минимального элемента
    min(a,5,m);
    cout<<"\n Индекс минимальной координаты вектора ="<<m;
    cout<<endl;
//Вычисления суммы между первым и вторым отрицательными элементами
    summ(a,5,S);
    cout<<"\n Сумма между первым и вторым отрицательными элементами="<<S;
    cout<<endl;
//Сортировка
    sort(a,5);
    cout<<"\n ***Вектор В***\n";
    cout<<endl;
}
//Функция для ввода координат вектора
void inputv(double x[],int n)
{//Объявляем переменную
    int i;
    for(i=0;i<n;i++)
    cin>>x[i];
}
//Функция для вывода вектора
void outputv(double x[],int n)
{//Объявление переменной
int i;
for (i=0;i<n;i++)
cout<<x[i];
}
//Вычисление номера минимального элемента массива
void min(double a[],int n,int&m)
{//Объявляем переменные
    int i;
    double k=a[0];
    //Вычисления
    for(i=1;i<n;i++)
        if (a[i]<k)
            {k=a[i];
            m=i;
            }
        
}
//Определение функции для суммы
void summ(double a[], int n, double&S)
{
    //Объявляем переменные
    int i,j;
    //Вычисления
    S=0;
    for(i=1;i<n;i++)
    {if(a[i]<0)
        {for(j=i+1;j<n;j++)
            {   if(a[j]<0) break;
                S=S+a[j];
            }
            break;
        }
    }
}
//Определение функции для сортировки
void sort(double a[], int n)
{//Объявляем переменные
    double b[5];
    int i,j=0;
//Вычисления
    for(i=0;j<n;i++)
    {if (fabs(a[i])<=1)
        {b[j]=a[i];
         j++;
        }
    
        for (i=0;i<n;i++)
        if (fabs(a[i])>1)
        {   b[j]=a[i];
            j++;
        }
    }
}

Работает все кроме сортировки!!! что не так сделал!?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.12.2010, 01:09
Ответы с готовыми решениями:

Сортировка массива по модулю
Преобразовать массив таким образом, чтобы сначала располагались все элементы, модуль которых не превышает 1, а потом — все остальные. Код...

Сортировка массива по модулю числа
Задание 1. Сортировка массива по модулю числа. Если модули чисел равны, то на понижение(например: если массив состоит из чисел 3, -3, 7,...

Метод пузырька: сортировка по модулю значений
Методом пузырька сортировать численные значения по значению абсолютной величины Метод пузырька получился, а вот как сделать сравнение по...

3
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
10.12.2010, 02:07
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#include <iostream>
#include <cmath>
using namespace std;
//Прототип функции для ввода вектора
void inputv(double x[],int n);
//Прототип функции для вывода вектора
void outputv(double x[],int n);
//Прототип функции для вычисления индекса минимального элемента
void min(double x[],int n,int&m);
//Прототип функции для вычисления суммы между первым и вторым отрицательными элементами
void summ(double x[],int n, double&S);
//Прототип функци для сортировки
void sort(double x[],int n);
//Главная функция
void main()
{//Руссификация
setlocale(LC_ALL,"Russian");
//Объявляем вектор и переменные
double a[5],S;
int m;
//Ввод вектора
cout<<"\n Ввести через пробел координаты вектора \n";
inputv(a,5);
 
//Вычисления индекса минимального элемента
min(a,5,m);
cout<<"\n Индекс минимальной координаты вектора ="<<m;
cout<<endl;
//Вычисления суммы между первым и вторым отрицательными элементами
summ(a,5,S);
cout<<"\n Сумма между первым и вторым отрицательными элементами="<<S;
cout<<endl;
//Сортировка
sort(a,5);
cout<<"\n ***Вектор В***\n";
outputv(a, 5);
cout<<endl;
}
//Функция для ввода координат вектора
void inputv(double x[],int n)
{//Объявляем переменную
int i;
for(i=0;i<n;i++)
cin>>x[i];
}
//Функция для вывода вектора
void outputv(double x[],int n)
{//Объявление переменной
int i;
for (i=0;i<n;i++)
cout<<x[i]<<" ";
}
//Вычисление номера минимального элемента массива
void min(double a[],int n,int&m)
{//Объявляем переменные
int i;
double k=a[0];
//Вычисления
for(i=1;i<n;i++)
if (a[i]<k)
{k=a[i];
m=i;
}
 
}
//Определение функции для суммы
void summ(double a[], int n, double&S)
{
//Объявляем переменные
int i,j;
//Вычисления
S=0;
for(i=1;i<n;i++)
{if(a[i]<0)
{for(j=i+1;j<n;j++)
{ if(a[j]<0) break;
S=S+a[j];
}
break;
}
}
}
//Определение функции для сортировки
void sort(double a[], int n)
{//Объявляем переменные
int i,j=0;
//Вычисления
for(i=0;i<n;i++)
{if (fabs(a[i])<=1)
{
    double temp=a[i];
    a[i]=a[j];
    a[j]=temp;
j++;
}
}
}
1
0 / 0 / 0
Регистрация: 09.12.2010
Сообщений: 22
12.12.2010, 17:56  [ТС]
Вот еще вопрос... а почему когда я ввожу массив и в не присутствует 0. То у меня не получается ни номер минимального элемента ни сумма. ?


Ввести через пробел координаты вектора
-8 4 68 0 -7

Индекс минимальной координаты вектора =-858993460

Сумма между первым и вторым отрицательными элементами=0

***Вектор В***
0 4 68 -8 -7
Для продолжения нажмите любую клавишу . . .
0
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
12.12.2010, 18:25
BorAl, У Вас написаны функции для вычисления номера минимального элемента и суммы не правильно:
C++
1
2
3
4
5
6
7
8
9
10
11
void min(double a[],int n,int&m)
{//Объявляем переменные
int i;
double k=a[0];
//Вычисления
for(i=1;i<n;i++)
if (a[i]<k)
{k=a[i];
m=i;
} 
}
когда осуществляется вход в функцию min() у переменной m нет вообще никакого значения. И если окажется что минимальный элемент самый первый, то m остается такой же как и была (с никаким значением).
А насчет суммы:
эту строку в функции summ():
C++
1
for(i=1;i<n;i++)
замените на эту:
C++
1
for(i=0;i<n;i++)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
12.12.2010, 18:25
Помогаю со студенческими работами здесь

Сортировка вектора векторов по модулю через лямбда функцию
Помогите пожалуйста. Требуется отсортировать функцией sort вектор векторов через лямбда функцию. Я написал сортировку для вектора. Помогите...

Обработка массива: максимальный по модулю, сумма в интервале и сортировка
Помогите, пожалуйста, с заданием, а то завал(( Необходимо написать программу, которая будет обрабатывать массив В массиве, который...

В матрице поменять местами максимальный по модулю и минимальный по модулю четные элементы
В прямоугольной целочисленной матрице обменять местами максимальный по модулю и минимальный по модулю четные элементы.

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

Cреднее арифметическое наименьшего по модулю и наибольшего по модулю элементов матрицы
Здравствуйте, помогите пожалуйста решить задачe, нужно до 5-го числа сдать. Дана действительная матрица размера m на n. Найти среднее...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
1С: Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью. Данные берутся из регистра сведений, по которому настроено. . .
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
1С: Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию группы. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
1С: Программный отбор элементов справочника по значению перечисления
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит значение перечислений. / / Событие "НачалоВыбора" реквизита на форме. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru