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

проблема с задачкой

16.10.2011, 10:53. Показов 994. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
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
#include <iostream>
using namespace std;
 int main() {
int n,i,max,min,N,m, sum=0;
int*A;
cout<<"vvedite razmer massiva n=";
cin>>n;
A=new int[n];
for(i=0;i<n;i++) {
cout<<"a["<<i+1<<"]=";
cin>>A[i]; }
 min=A[0];
    for (i=0;i<n;i++)
    {
       if (A[i]<=min)
       {
          min=A[i];
          N=i+1;
       }
    }
    max=A[0];
    for (i=0;i<n;i++)
    {
       if (A[i]>=max)
       {
          max=A[i];
          m=i+1;
       }
    }
 
 
    for(i=0;i<n;i++)
{
     if((A[i]>min&&A[i]<max)&&A[i]>0)
    { sum=sum+A[i];
 
    }
}
 
 
    cout << N << ") ,min= " << min << endl;
    cout << m << ") ,max= " << max << endl;
   cout << "Summa="<<sum;
    return 0;
}
мне нужно посчитать сумму положительных элементов между мин и макс ( 1,-4,3,-2,4,7. сумма = 3+4)

 Комментарий модератора 
Используйте теги форматирования кода!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.10.2011, 10:53
Ответы с готовыми решениями:

Проблема с задачкой
вот скрин задания: http://floomby.ru/content/bM0lY7319U Вот что я написал: #include&lt;iostream.h&gt; #include&lt;math.h&gt; ...

помогите с задачкой
дано натуральное семизначное число n. определить встречается ли в нем заданная цифра A. если встречается то сколько раз?

помогите с задачкой
собственно есть вот такая задачка... сори если не туда написал. Дана матрица A,...

12
 Аватар для @r!er
2 / 2 / 1
Регистрация: 15.09.2011
Сообщений: 25
16.10.2011, 11:17
Сделай проще:
C++
1
2
3
4
5
6
7
8
9
10
11
12
 // поиск минимального и максимального элементов
 int iMin=0, iMax=0;
 for(int i=1; i<n; i++)
 {
  if(A[i]<=A[iMin]) iMin=i;
  if(A[i]>=A[iMax]) iMax=i;
 }
 // сумма элементов, расположенных между минимальным и максимальным
 int d=iMax<iMin?-1:iMax>iMin?1:0;
 int sum=0;
 for(int i=iMin+d; i!=iMax; i+=d)
 sum+=A[i];
0
0 / 0 / 1
Регистрация: 16.10.2011
Сообщений: 28
16.10.2011, 11:21  [ТС]
я новичок и мне не понятен ваш код(
0
 Аватар для @r!er
2 / 2 / 1
Регистрация: 15.09.2011
Сообщений: 25
16.10.2011, 11:22
Цитата Сообщение от Fenita Посмотреть сообщение
я новичок и мне не понятен ваш код(
Что именно не понятно? Спрашивай
0
0 / 0 / 1
Регистрация: 16.10.2011
Сообщений: 28
16.10.2011, 11:26  [ТС]
Цитата Сообщение от @r!er Посмотреть сообщение
Что именно не понятно? Спрашивай
как находится сумма между минимальным и максимальным элементом, и суммируются только положительные числа?
0
 Аватар для @r!er
2 / 2 / 1
Регистрация: 15.09.2011
Сообщений: 25
16.10.2011, 11:45
Цитата Сообщение от Fenita Посмотреть сообщение
как находится сумма между минимальным и максимальным элементом, и суммируются только положительные числа?
Пардон, в 12 строчке:
C++
1
if(A[i]>0) sum+=A[i];
Сначала опеределяешь, какой из элементов (максимальный или минимальный) расположен левее:
C++
1
int d=iMax<iMin?-1:iMax>iMin?1:0;
т.е., если левее расположен максимальный элемент, d=-1, наоборот - d=1. Если массив из одинаковых элементов d=0.
Затем задаем цикл:
C++
1
for(int i=iMin+d; i!=iMax; i+=d)
от номера минимального элемента + шаг смешения(d) до максимального. В зависимости от того, какой элемент левее, шаг будет либо 1, либо -1.
В цикле проверяем условие (A[i]>0) и суммируем положительные элементы

Добавлено через 9 минут
Цитата Сообщение от @r!er Посмотреть сообщение
C++
1
int d=iMax<iMin?-1:iMax>iMin?1:0;
Здесь используется тернарная операция ?:
0
0 / 0 / 1
Регистрация: 16.10.2011
Сообщений: 28
16.10.2011, 16:25  [ТС]
спасибо, большое еще пару вопросов, что такое терная операция и можно ли обойтись без нее, и как еще определить и вывести номера элементов, удовлетворяющих этому же условию?
0
 Аватар для @r!er
2 / 2 / 1
Регистрация: 15.09.2011
Сообщений: 25
16.10.2011, 16:40
Цитата Сообщение от Fenita Посмотреть сообщение
спасибо, большое еще пару вопросов, что такое терная операция и можно ли обойтись без нее, и как еще определить и вывести номера элементов, удовлетворяющих этому же условию?
Тернарная операция имеет вид:
условие ? выражение1 : выражение 2;
Если условие истинно, то выполняется выражение 1, иначе (условие ложно) выполняется выражение 2.

Конечно можно обойтись без неё:
C++
1
2
3
4
int d;
if(iMax<iMin) d=-1;
if(iMax>iMin) d=1;
if(iMax=iMin) d=0;
Номера элементов хранятся в переменных iMin и iMax. Сохранят значение элемента смысла нет, т.к. его всегда можно найти по индексам (iMin, iMax) в самом массиве.
0
0 / 0 / 1
Регистрация: 16.10.2011
Сообщений: 28
16.10.2011, 16:46  [ТС]
спасибо, вроде бы разобрался, но у меня в задании еще написано вывести номера этих элементов
0
 Аватар для @r!er
2 / 2 / 1
Регистрация: 15.09.2011
Сообщений: 25
16.10.2011, 16:50
Цитата Сообщение от Fenita Посмотреть сообщение
спасибо, вроде бы разобрался, но у меня в задании еще написано вывести номера этих элементов
OK
C++
1
2
3
4
cout<<"Номер максимального элемента: "<<iMax<<endl;
cout<<"Максимальный элемент: "<<A[iMax]<<endl;
cout<<"Номер минимального элемента: "<<iMin<<endl;
cout<<"Минимальный элемент: "<<A[iMin]<<endl;
0
0 / 0 / 1
Регистрация: 16.10.2011
Сообщений: 28
16.10.2011, 16:53  [ТС]
нет, Вы не поняли, надо ни номера макисального и минимального, а номера тех элементов, которые складывались в сумму
0
 Аватар для @r!er
2 / 2 / 1
Регистрация: 15.09.2011
Сообщений: 25
16.10.2011, 17:05
Цитата Сообщение от Fenita Посмотреть сообщение
нет, Вы не поняли, надо ни номера макисального и минимального, а номера тех элементов, которые складывались в сумму
Можно, например, в том же цикле, где считается сумма, сразу выводить номера положительных элементов:
C++
1
2
3
4
5
6
int sum=0, j=0;
for(int i=iMin+d; i!=iMax; i+=d)
{
 sum+=A[i];
 cout<<"Номер "<<++j<<"-го положительного элемента: "<<i<<endl;
}
0
0 / 0 / 1
Регистрация: 16.10.2011
Сообщений: 28
16.10.2011, 17:13  [ТС]
Спасибо большое, выручили
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.10.2011, 17:13
Помогаю со студенческими работами здесь

Помогите с задачкой
нужно написать калькулятор который считал бы введенные данные без приоритетов(те умножите и дельте не приоритет) вводим такие данные ...

Помогите с Задачкой
1. Реализовать функцию нахождения всех простых чисел в диапазоне от 1 до 101. Сгенерированные числа сохранить в массиве. Элементы массива...

Помогите с задачкой
Давно не работал с Visual С++ (( и напрочь забыл много чего. _______________________________________________________ Условие задачи: ...

Помогите с задачкой.
Поместить элементы массива X в начало массива Y в обратном порядке, исключив элементы, превосходящие по абсолютной величине вводимое...

Sos с задачкой
Помогите с задачкой по питону не получается решение (не судите строго я начинающий). Нужно чтобы с помощью цикла for написать задачку ,...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
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
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru