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

Массив: Вычислить минимальный элемент массива

06.05.2021, 19:54. Показов 764. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В одномерном массиве, состоящем из N действительных элементов, вычислить:
- минимальный элемент массива;
- сумму элементов массива, расположенных между первым и последним положительными элементами.

Превратить массив так, чтобы сначала располагались все элементы, которые равны
нулю, а затем - все остальные.
Как переделать, чтобы использовать операции над элементами использовать указатели?

Вот код
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
#include <iostream> 
#include <iomanip> 
using namespace std; 
int main() 
{ 
  const int size = 10; 
  double arr[size]; 
  double sum; 
  double min; 
  int i,j; 
// формирование массива 
  for (i=0; i<size; i++) 
 { 
    cout << "arr[" << i << "]="; cin >> arr[i]; 
 } 
 
// эхо-печать массива 
  cout << "Введенный массив" << endl; 
  for (i=0; i<size; i++)  
  { 
    cout << i << " " << setprecision(3) << arr[i] << endl; 
  } 
// поиск минимального элемента 
  for (i=0, min=arr[0]; i<size; i++) 
    if (arr[i]<min) min = arr[i]; 
// поиск первого положительного элемента 
  for (i=0; i<size && arr[i]<=0; i++) ; 
  sum = 0; 
// если нет вообще положительных элементов 
//поиск последнего положительного элемента 
  if ((i<size-2) && (arr[i]>0)) 
// а есть ли смысл? 
{ 
  for (j=size-1; j>=0 && arr[j]<=0; j--) ; 
  if ((arr[j]>0) && (--j>i)) 
    while (j>i) 
   { 
// сумма элементов между первым и последним положительным 
    sum+=arr[j--]; 
  } 
} 
 
  for (i=j=size-1; i>=0;--i) 
  { 
     if (arr[i]!=0) 
    {
       if (i!=j) arr[j]=arr[i]; --j; 
    } 
  } 
 
// заполним начало нулями 
  for (i=0;i<=j;i++) 
    arr[i]=0; 
 
// печать нового массива 
  cout << endl; 
  cout << "Новый массив" << endl; 
  for (i=0; i<size; i++) 
  { 
    cout << i << " " << setprecision(3) << arr[i] << endl; 
  } 
  cout << "Минимальный элемент =" << setprecision(3) << min << endl; 
  cout << "Сумма между первым и последним положительными элементами = "; 
  cout << setprecision(3); 
  cout << sum << endl;  
  system("pause"); 
  return 0; 
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
06.05.2021, 19:54
Ответы с готовыми решениями:

Массивы. Вычислить минимальный элемент массива, сумму элементов массива, преобразовать массив
При написании программ использовать динамические массивы. Размерность массивов задаётся именованной константой. Задача 2. В...

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

Есть числа в файле "student.txt". Нужно считать их в массив и вычислить минимальный элемент массива
помогите пожалуйста с программой в С++

7
 Аватар для stdin
129 / 81 / 49
Регистрация: 10.01.2020
Сообщений: 293
06.05.2021, 20:02
Цитата Сообщение от Paterson Посмотреть сообщение
Как переделать, чтобы использовать операции над элементами использовать указатели?
А чуть конкретнее?
0
0 / 0 / 0
Регистрация: 06.05.2021
Сообщений: 6
06.05.2021, 20:11  [ТС]
Вместо классического доступа к элементам массива (например, MyArray [i])
и выполнения операций над элементами использовать указатели.
Обработку массива выполнить в функциях, вызываемых с помощью указателя.
0
 Аватар для stdin
129 / 81 / 49
Регистрация: 10.01.2020
Сообщений: 293
06.05.2021, 20:14
Paterson, возможно вы имеете ввиду такой синтаксис:
C++
1
*(MyArray + i) // равнозначимо MyArray[i]
Если не разыменовывать указатель, то:
C++
1
(MyArray + i)
0
0 / 0 / 0
Регистрация: 06.05.2021
Сообщений: 6
06.05.2021, 22:47  [ТС]
если заменить arr [i] на * (arr + i), то выводит только минимальное число, немного неправильно сортирует и при любых числа сумма равна 0
0
 Аватар для stdin
129 / 81 / 49
Регистрация: 10.01.2020
Сообщений: 293
06.05.2021, 22:57
Paterson, Во-первых, это два равнозначимых синтаксиса разименовки указателя на элемент массива.
Во-вторых, нет кода, чтобы увидеть как вы заменили.
0
0 / 0 / 0
Регистрация: 06.05.2021
Сообщений: 6
06.05.2021, 23:20  [ТС]
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
#include <iostream> 
#include <iomanip> 
using namespace std; 
int main() 
{ 
  const int size = 10; 
  double arr[size]; 
  double sum; 
  double min; 
  int i,j; 
// формирование массива 
  for (i=0; i<size; i++) 
 { 
    cout << "arr[" << i << "]="; cin >> *(arr+i); 
 } 
 
// эхо-печать массива 
  cout << "Введенный массив" << endl; 
  for (i=0; i<size; i++)  
  { 
    cout << i << " " << setprecision(3) << *(arr+i) << endl; 
  } 
// поиск минимального элемента 
  for (i=0, min=*(arr+0); i<size; i++) 
    if (*(arr+i)<min) min = *(arr+i); 
// поиск первого положительного элемента 
  for (i=0; i<size && *(arr+i)<=0; i++) ; 
  sum = 0; 
// если нет вообще положительных элементов 
//поиск последнего положительного элемента 
  if ((i<size-2) && (*(arr+i)>0)) 
// а есть ли смысл? 
{ 
  for (j=size-1; j>=0 && *(arr+j)<=0; j--) ; 
  if ((*(arr+j)>0) && (--j>i)) 
    while (j>i) 
   { 
// сумма элементов между первым и последним положительным 
    sum+=*(arr+j--); 
  } 
} 
 
  for (i=j=size-1; i>=0;--i) 
  { 
     if (*(arr+i)!=0) 
    {
       if (i!=j) *(arr+j)=*(arr+i); --j; 
    } 
  } 
 
// заполним начало нулями 
  for (i=0;i<=j;i++) 
    *(arr+i)=0; 
 
// печать нового массива 
  cout << endl; 
  cout << "Новый массив" << endl; 
  for (i=0; i<size; i++) 
  { 
    cout << i << " " << setprecision(3) << *(arr+i) << endl; 
  } 
  cout << "Минимальный элемент =" << setprecision(3) << min << endl; 
  cout << "Сумма между первым и последним положительными элементами = "; 
  cout << setprecision(3); 
  cout << sum << endl;  
  system("pause"); 
  return 0; 
}
0
 Аватар для stdin
129 / 81 / 49
Регистрация: 10.01.2020
Сообщений: 293
07.05.2021, 14:34
Paterson, сумму оно считает вроде правильно, а вот насчет всего остального, видимо с i и j что-то накрутили.
Посмотрите в отладчике значения этих переменных.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.05.2021, 14:34
Помогаю со студенческими работами здесь

В одномерном массиве, состоящем из n элементов массива, вычислить минимальный элемент массива
помогите

Вычислить минимальный элемент массива
Вечер добрый.Имеется две задачи:. В одномерном массиве, состоящем из n вещественных элементов вычислить минимальный элемент массива. ...

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

Вычислить минимальный элемент массива
В одномерном массиве, состоящем из действительных элементов, вычислить минимальный элемент массива;

Вычислить минимальный по модулю элемент массива
Выполнить следующее задание, оформив каждый пункт в виде функции. Все необходимые дан-ные для функций должны передаваться им в качестве...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение/ Перевод Сайт называется reddit: The Thinkpad X220 Tablet is the best budget school laptop period. Это. . .
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