Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
110 / 1 / 2
Регистрация: 10.12.2015
Сообщений: 93

Найти сумму элементов массива до минимального элемента

02.01.2016, 17:16. Показов 911. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам


Надо доделать по заданию , помогите не получается сделать 2-ое и 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
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
#include <iostream>
#include <stdlib.h>  //подключаем библиотеки для rand и time
#include <time.h>  
using namespace std;
 
int main ()
{
    char a ;
    cout << " For random fill press 1 " <<endl ;
    cout << " For custom fill press 2 " << endl ;
    cin >> a;
    
   
    if (a =='1'){
    cout << "random fill" ;   
    int n , s;
    cout << " Enter amount of elements: " << endl ;
    cin >> n ;
    float *matrix = new float[n];
    cout << endl ;
    
    srand((unsigned int)time(NULL)); // Zapolnenije randomnimi chislami
 
  int a1 = 0, a2 = -1;  // Введение интервала доступных чисел
  cout << "Enter [a:b]" << endl;
  cout << "Enter a: ";
  cin >> a1;
  cout << "Enter b: ";
  cin >> a2;
 
  for (int i = 0; i < n; i++)
 
   matrix[i] = a1 + rand() % (a2 - a1 + 1);
  cout << "Matrix:" << endl;
  for (int i = 0; i < n; i++){
 
   cout << matrix[i] << " ";
   
   }
 for (int i = 0; i < n; i++) // summa chisel
 if (matrix[i] > 0) 
 s += matrix[i] ;
 cout << s ;
   }    
  else if (a=='2'){
  cout << "custom fill" ; 
  int n , s , j , x , k;
  cout << " Enter amount of elements: " << endl ;
  cin >> n ;
  float *matrix = new float[n];
  cout << endl ;
  for (int i = 0; i < n; i++){
  cout << " Enter element " ;
  cin >> matrix[i] ;
  
  }
  
 for (int i = 0; i < n; i++) // summa elementov do minimaljnogo
 if (matrix[i] > 0) 
 s += matrix[i] ;
 cout << s ;
  
j = matrix[0];
  for (int i = 0; i<n; i++)
  {
   if (matrix[i]>j) {
    j = matrix[i];
    x = i + 1;
   }
  }
  for (int i = x; i<n; i++)
   k += matrix[i];
 cout << k ; 
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.01.2016, 17:16
Ответы с готовыми решениями:

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

Найти сумму элементов массива, расположенных после минимального элемента
Дан массив действительных чисел b1;…;b10 .. Найти сумму элементов расположенных после минимального элемента.

Найти номер минимального элемента массива; найти сумму элементов, удовлетворяющих условию
1. Найти номер минимального элемента массива. 2. Найти сумму элементов массива, расположенных между первым и вторым от- рицательными...

8
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
02.01.2016, 17:29
orbaki, Что во 2-м может быть не понятного? Добавьте переменную min = 0 и после строки 33 проверяйте больше ли эта переменная только что сгенерированного числа, если больше, приравниваете min к i. Потом создаёте цикл, проходящий по всем элементам массива и пока min != i суммируете в какую-либо переменную все числа.

Добавлено через 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
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
#include <iostream>
#include <stdlib.h>  //подключаем библиотеки для rand и time
#include <time.h>  
using namespace std;
 
int main ()
{
    char a ;
    cout << " For random fill press 1 " <<endl ;
    cout << " For custom fill press 2 " << endl ;
    cin >> a;
    int min = 0; // add
    bool min_p = true; // add
    int sum = 0; // add
    
   
    if (a =='1'){
    cout << "random fill" ;   
    int n , s;
    cout << " Enter amount of elements: " << endl ;
    cin >> n ;
    float *matrix = new float[n];
    cout << endl ;
    
    srand((unsigned int)time(NULL)); // Zapolnenije randomnimi chislami
 
  int a1 = 0, a2 = -1;  // Введение интервала доступных чисел
  cout << "Enter [a:b]" << endl;
  cout << "Enter a: ";
  cin >> a1;
  cout << "Enter b: ";
  cin >> a2;
 
  for (int i = 0; i < n; i++)
 
   matrix[i] = a1 + rand() % (a2 - a1 + 1);
   if( matrix[min] > matrix[i] ) min = i; // add
  cout << "Matrix:" << endl;
  for (int i = 0; i < n; i++){
 
   cout << matrix[i] << " ";
   if( i == min ) min_p = false; // add
   if( min_p ) sum += matrix[i]; // add
   
   }
 for (int i = 0; i < n; i++) // summa chisel
 if (matrix[i] > 0) 
 s += matrix[i] ;
 cout << s ;
   }    
  else if (a=='2'){
  cout << "custom fill" ; 
  int n , s , j , x , k;
  cout << " Enter amount of elements: " << endl ;
  cin >> n ;
  float *matrix = new float[n];
  cout << endl ;
  for (int i = 0; i < n; i++){
  cout << " Enter element " ;
  cin >> matrix[i] ;
  
  }
  
 for (int i = 0; i < n; i++) // summa elementov do minimaljnogo
 if (matrix[i] > 0) 
 s += matrix[i] ;
 cout << s ;
  
j = matrix[0];
  for (int i = 0; i<n; i++)
  {
   if (matrix[i]>j) {
    j = matrix[i];
    x = i + 1;
   }
  }
  for (int i = x; i<n; i++)
   k += matrix[i];
 cout << k ; 
}
0
 Аватар для SergioO
261 / 209 / 99
Регистрация: 13.12.2015
Сообщений: 1,098
02.01.2016, 17:34
Цитата Сообщение от makfak Посмотреть сообщение
Добавьте переменную min = 0 и после строки
а если все элементы массива больше нуля?
0
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
02.01.2016, 17:36
SergioO, Мы не проверяем больше ли min 0, мы проверяем 1-й элемент массива > элемента массива[i]

Добавлено через 26 секунд
Код-то посмотрите, я всё что добавил отметил комментариями.
0
110 / 1 / 2
Регистрация: 10.12.2015
Сообщений: 93
02.01.2016, 17:52  [ТС]
это все 3 задания? просто вижуал щас не пашет делаю все через cpp.sh
дает следующие ошибки по строкам -
37:29: error: 'i' was not declared in this scope
80:1: error: expected '}' at end of input
0
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
02.01.2016, 18:08
orbaki, Это все 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
#include <iostream>
#include <stdlib.h>  //подключаем библиотеки для rand и time
#include <time.h>  
using namespace std;
 
int main ()
{
    char a ;
    cout << " For random fill press 1 " <<endl ;
    cout << " For custom fill press 2 " << endl ;
    cin >> a;
    int min = 0; // add
    bool min_p = true; // add
    int sum = 0; // add
    
   
    if (a =='1'){
    cout << "random fill" ;   
    int n , s;
    cout << " Enter amount of elements: " << endl ;
    cin >> n ;
    float *matrix = new float[n];
    cout << endl ;
    
    srand((unsigned int)time(NULL)); // Zapolnenije randomnimi chislami
 
  int a1 = 0, a2 = -1;  // Введение интервала доступных чисел
  cout << "Enter [a:b]" << endl;
  cout << "Enter a: ";
  cin >> a1;
  cout << "Enter b: ";
  cin >> a2;
 
  for (int i = 0; i < n; i++) {
      matrix[i] = a1 + rand() % (a2 - a1 + 1);
      if( matrix[min] > matrix[i] ) min = i; // add
  }
  cout << "Matrix:" << endl;
  for (int i = 0; i < n; i++){
 
   cout << matrix[i] << " ";
   if( i == min ) min_p = false; // add
   if( min_p ) sum += matrix[i]; // add
   
   }
 cout << sum;
   }    
  else if (a=='2'){
  cout << "custom fill" ; 
  int n , s , j , x , k;
  cout << " Enter amount of elements: " << endl ;
  cin >> n ;
  float *matrix = new float[n];
  cout << endl ;
  for (int i = 0; i < n; i++){
  cout << " Enter element " ;
  cin >> matrix[i] ;
  if( matrix[min] > matrix[i] ) min = i; // add
  }
  
 for (int i = 0; i < n; i++) { // summa elementov do minimaljnogo
 if( i == min ) min_p = false; // add
 if( min_p ) sum += matrix[i]; // add
 }
 cout << sum ;
  
j = matrix[0];
  for (int i = 0; i<n; i++)
  {
   if (matrix[i]>j) {
    j = matrix[i];
    x = i + 1;
   }
  }
  for (int i = x; i<n; i++)
   k += matrix[i];
 cout << k ; 
}
0
110 / 1 / 2
Регистрация: 10.12.2015
Сообщений: 93
02.01.2016, 18:14  [ТС]
мне бы еще упорядочить все элементы
0
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
02.01.2016, 18:20
orbaki,
C++
1
2
3
4
5
6
7
8
9
10
11
j = matrix[0];
 for (int i = 0; i<n; i++)
 {
 if (matrix[i]>j) {
  j = matrix[i];
  x = i + 1;
 }
 }
 for (int i = x; i<n; i++)
 k += matrix[i];
cout << k ;
Вот этот кусок это что? Его можно убрать?
1
110 / 1 / 2
Регистрация: 10.12.2015
Сообщений: 93
02.01.2016, 18:24  [ТС]
Спасибо!!!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.01.2016, 18:24
Помогаю со студенческими работами здесь

Найти сумму элементов массива, расположенных после первого минимального элемента
Уважаемые программисты, помогите пожалуйста решить задачи изложенные ниже с использованием библиотеки &quot;math&quot;. Задание: В...

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

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

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

Найти сумму модулей элементов массива, расположенных после минимального по модулю элемента
в одномерном массиве {3.24, -7.16, 2.28, -0.16, -3.22, 7.14, 2.88, -3.20, 0.99, -4.15} найти сумму модулей элементов массива, расположенных...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение/ Перевод https:/ / **********/ gallery/ thinkpad-x220-tablet-porn-gzoEAjs . . .
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