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

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

04.10.2010, 22:04. Показов 30329. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение Это мой обзор планшета X220 с точки зрения школьника. Недавно я решила попытаться уменьшить свой. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru