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

Найти сумму модулей элементов массива, расположенных после первого отрицательного элемента

04.10.2010, 22:04. Показов 30414. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В одномерном массиве, состоящем из n вещественных элементов, вычислить:
1) номер минимального по модулю элемента массива;
2) сумму модулей элементов массива, расположенных после первого от-
рицательного элемента.
ПОМОГИТЕ, ЖЕЛАТЕЛЬНО СРОЧНО!!!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
04.10.2010, 22:04
Ответы с готовыми решениями:

Найти сумму модулей элементов массива, расположенных после первого отрицательного элемента
Найти сумму модулей элементов массива, расположенных после первого отрицательного элемента. Вот код: #include <conio.h> ...

Шаблонная функция вычисляющая сумму модулей элементов массива, расположенных после первого отрицательного элемента
1. Реализовать шаблон для одномерного массива любого типа. 2. Реализовать шаблон функции которая выполняет следующие действия для...

Вычислить номер минимального по модулю элемента и сумму модулей элементов, расположенных после первого отрицательного
Добрый день. Прошу Вашей помощи. В одномерном массиве, состоящем из n вещественных элементов, вычислить: 1) номер минимального по...

10
Эксперт С++
516 / 421 / 92
Регистрация: 23.09.2010
Сообщений: 1,165
04.10.2010, 22:29
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
#include <iostream>
#include <cstdlib>
#include <algorithm>
#include <cmath>
#include <functional>
 
using namespace std;
 
bool find_less_mod(int val1, int val2)
{
    return abs(val1)<abs(val2);
}
 
int sum_mod(int val1, int val2)
{
    return abs(val1)+abs(val2);
}
 
int main()
{
    const size_t n=6;
    int arr[n]{12, 2, -3, 15, -12, 4};
    size_t ind=min_element(arr, arr+n, find_less_mod)-arr;
    cout<<"Index of minimal element by modul: "<<ind<<endl;
    cout<<"Sum: "<<accumulate(find_if(arr, arr+n, bind2nd(less<int>(), 0))+1, arr+n, 0, sum_mod)<<endl;
    system("pause");
}
1
 Аватар для MILAN
899 / 793 / 186
Регистрация: 21.02.2009
Сообщений: 1,722
04.10.2010, 22:33
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
#include <iostream>
#include <ctime>
using std::cout;
using std::cin;
using std::endl;
 
int main()
{
    srand(time(NULL)); 
    setlocale( LC_ALL,"Russian" );
    int size,i,min;
    int* mas;
    cout<<"Введите розмерность масива: ";
    cin>>size;
    mas = new int[size];
     for(i=0; i<size; i++)
     {
         mas[i]=rand()%9;
         cout<<mas[i]<<" ";
     }
     min = abs(mas[0]);
     for(i=0;i<size;i++)
     {
         if(abs(mas[i])<abs(min))
             min=i;
 
     }
     cout<<endl;
     cout<<"Minimum is "<<min<<"element";
     delete [] mas;
  return 0;
}
1
365 / 366 / 167
Регистрация: 11.06.2010
Сообщений: 703
04.10.2010, 22:35
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
#include <iostream>
#include <conio.h>
#include <math.h>
 
using namespace std;
 
void main()
{
    int i,n,i_min,min,ot,s=0;
    cout<<"  N=";
    cin>>n;
    int *a=new int [n];
    cout<<"\n  Enter elements: ";
     for(i=0;i<n;i++) cin>>a[i]; 
    i_min=0;
    min=abs(a[i]); 
     for(i=1;i<n;i++) 
      if(abs(a[i])<min) { min=a[i]; i_min=i; }
     for(i=0;i<n;i++) 
      if(a[i]<0) { ot=i; break; }
     for(i=ot;i<n;i++) s+=abs(a[i]);
    cout<<"\n\n  i_min="<<i_min+1;
    cout<<"\n  S="<<s; 
    delete []a;    
    getch();
}
1
0 / 0 / 0
Регистрация: 04.10.2010
Сообщений: 3
04.10.2010, 22:39  [ТС]
Эммм, а можно поподробней, что к чему
0
365 / 366 / 167
Регистрация: 11.06.2010
Сообщений: 703
04.10.2010, 22:45
Что именно не понятно???
0
0 / 0 / 0
Регистрация: 04.10.2010
Сообщений: 3
04.10.2010, 22:47  [ТС]
Хм, какое решение к какой задаче, и если можно, толкование операторов
0
365 / 366 / 167
Регистрация: 11.06.2010
Сообщений: 703
04.10.2010, 22:54
Мое к двум

Добавлено через 3 минуты
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
#include <iostream>
#include <conio.h>
#include <math.h>
 
using namespace std;
 
void main()
{
    int i,n,i_min,min,ot,s=0;
    cout<<"  N=";
    cin>>n;
    int *a=new int [n];
    cout<<"\n  Enter elements: ";
     for(i=0;i<n;i++) cin>>a[i]; //ввод массива;
    i_min=0;
    min=abs(a[i]); 
     for(i=1;i<n;i++) 
      if(abs(a[i])<min) { min=a[i]; i_min=i; } //поиск минимального по модулю элемента массива;
     for(i=0;i<n;i++) 
      if(a[i]<0) { ot=i; break; } //поиск первого отрицательного элемента;
     for(i=ot;i<n;i++) s+=abs(a[i]); //сумма модулей элементов массива, расположенных после первого отрицательного элемента;
    cout<<"\n\n  i_min="<<i_min+1;
    cout<<"\n  S="<<s; 
    delete []a;    
    getch();
}
0
 Аватар для MILAN
899 / 793 / 186
Регистрация: 21.02.2009
Сообщений: 1,722
04.10.2010, 22:55
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
#include <iostream>
#include <ctime>
using std::cout;
using std::cin;
using std::endl;
 
int main()
{
        srand(time(NULL)); 
    setlocale( LC_ALL,"Russian" );
        int size,i,min;//инициализация переменых
        int* mas;//инициализация указателя  
        cout<<"Введите розмерность масива: ";
        cin>>size;// ввод розмерности масива
        mas = new int[size];// выдиления памяти под масив 
         for(i=0; i<size; i++) // заполнение масива случайными числами
         {
                 mas[i]=rand()%9;
                 cout<<mas[i]<<" ";// вывод елемента масива
         }
         min = abs(mas[0]); // присвоение min первого елемента масива
         for(i=0;i<size;i++) // поиск минимального елемента
         {
                 if(abs(mas[i])<abs(min)) //если елемент по модулю менше минимума
                         min=i; // присвоить минимуму номер елемента масива
 
         }
         cout<<endl; 
         cout<<"Minimum is "<<min<<"element";// вывод номера минимального елемента
         delete [] mas; // очищение памяти
  return 0;
}
0
В астрале
Эксперт С++
 Аватар для ForEveR
8049 / 4806 / 655
Регистрация: 24.06.2010
Сообщений: 10,562
04.10.2010, 23:04
Позволю себе прокомментить код gooseim-а.

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
#include <iostream>
#include <cstdlib>
#include <algorithm>//Стандартные алгоритмы
#include <cmath>
#include <functional>//Функторы
#include <numeric> //Для accumulate
 
using namespace std;
 
bool find_less_mod(int val1, int val2)//Функция сравнения по модулю
{
    return abs(val1)<abs(val2);//Если модуль val1 меньше модуля val2 вернем 1, если нет - 0
}
 
int sum_mod(int val1, int val2)//Функция суммы по модулю
{
    return abs(val1)+abs(val2);//Возвращаем сумму модулей элементов
}
 
int main()
{
    const size_t n=6;//Размер
    int arr[n]{12, 2, -3, 15, -12, 4};
    size_t ind=min_element(arr, arr+n, find_less_mod)-arr;//Ищем минимальный по подулю элемент
//с помощью стандартного алгоритма min_element, после чего вычитаем из него адрес указателя
//на массив, получаем порядковый номер в массиве минимального по модулю элемента
    cout<<"Index of minimal element by modul: "<<ind<<endl;//Пишем это
    //Считаем сумму через accumulate. Первый параметр стандартный алгоритм find_if
//который ищет первый элемент меньше нуля, прибавляем к значению 1, получаем
//указатель на следующий за первым элементом больше нуля.
//От этого указателя до указателя на конец массива, складываем элементы массива функцией
//сумма по модулю.
    cout<<"Sum: "<<accumulate(find_if(arr, arr+n, bind2nd(less<int>(), 0))+1, arr+n, 0, sum_mod)<<endl;
    system("pause");
}
1
Эксперт С++
 Аватар для fasked
5045 / 2624 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
04.10.2010, 23:46
вторая:
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
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
 
#define SIZE 10
 
int main()
{
    int i = 0;
    int sum = 0;
    int values[SIZE];
    
    for(i = 0; i < SIZE; ++i)
        values[i] = rand() % 9 - rand() % 9;
    
    for(i = 0; i < SIZE && values[i] > 0; ++i);
    for(i = i + 1; i < SIZE; ++i)
        sum += abs(values[i]);
    
    for(i = 0; i < SIZE; ++i)
        printf("%d ", values[i]);
    printf("\nsum: %d\n", sum);
    
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
04.10.2010, 23:46
Помогаю со студенческими работами здесь

Найти сумму модулей элементов массива, расположенных после первого элемента, равного нулю
Народ нужна помощь помогите с програмой не могу завтро зачет не могу ее написать) Вот задача:В одномерном массиве, состоящем из n целых...

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

Найти сумму модулей элементов массива, расположенных после первого элемента, равного нулю.
Массив состоящий из 10 элементов заполнить случайными числами. Найти сумму модулей элементов массива, расположенных после первого элемента,...

Найти номер минимального по модулю элемента массива и сумму модулей после первого отрицательного элемента
1.В одномерном массиве, состоящем из n вещественных элементов, вычислить: а)номер минимального по модулю элемента массива; б)сумму...

Определить сумму элементов массива, расположенных после первого отрицательного элемента
Создать массив из 20 случайных чисел в диапазоне от -10 до 30. Определить сумму элементов массива, расположенных в массиве после...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru