Форум программистов, компьютерный форум CyberForum.ru

В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.70
ka4ok73
1 / 1 / 0
Регистрация: 22.03.2010
Сообщений: 18
03.12.2010, 23:05     В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива #1
Есть программа, которая выполняет следующее:
1) Ввод массива 3 разными способами.
2) Удаляет из массива первый из нечётных элементов.

Нужно изменить код так, чтобы программа вместо Удаления из массива первого из нечётных элементов, находила сумму элементов, расположенных между минимальным и максимальным элементами массива.
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include <time.h>
#include <malloc.h>
 
//================================================
void keybord(int *Arr, int n)
{
int i;
for(i = 0; i < n; ++i)
{
     printf("Enter Arr[%d]: ", i);
     scanf("%d", &Arr[i]);
}
 
printf("Array\n");
for(i = 0; i < n; ++i)
{
     printf("%d ", Arr[i]);
}
printf("\n");
}
//================================================
void random(int *Arr, int n)
{
int i;
   printf("Array\n");
for(i = 0; i < n; ++i)
{
Arr[i] = rand()%100+1+i;
printf("%d ", Arr[i]);
}
printf("\n");
}
//================================================
void from_file(int *Arr, int n)
{
int i;
FILE* f;
f=fopen("1.txt", "r");
if(f==NULL)
{
    printf("Error!\n");
    exit(1);
}
printf("Array\n");
for(i = 0; i < n; ++i)
{
fscanf(f, "%d ", &Arr[i]);
printf("%d ", Arr[i]);
}
printf("\n");
fclose(f);
}
//================================================
void foo(int *Arr, int n)
{
int index = 0, i;
 
for(i = 0; i <n; ++i)
{
if(Arr[index] < Arr[i])
{
index = i;
}
}
 
for(i = index+1; i < n; ++i)
{
Arr[i]--;
}
}
 
//================================================
int main()
{
srand((unsigned)(time(NULL)));
int *Arr, n, x;
printf("Enter size of array: ");
scanf("%d", &n);
Arr =(int*)malloc(sizeof(int)*n);
 
printf("Enter elements of array\n");
printf("1 - keyboard\n");
printf("2 - random\n");
printf("3 - file\n");
 
printf("Enter number of option: ");
scanf("%d", &x);
 
switch(x)
{
case 1:
keybord(Arr, n);
break;
case 2:
random(Arr, n);
break;
case 3:
from_file(Arr, n);
break;
default:
printf("Error\n");
return 1;
}
 
foo(Arr, n);
 
printf("After\n");
int i;
for(i = 0; i < n; ++i)
{
printf("%d ", Arr[i]);
}
printf("\n");
getch ();
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.12.2010, 23:05     В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива
Посмотрите здесь:

C++ Найти сумму элементов массива, расположенных между элементами с минимальным и максимальным значением
Найти сумму элементов массива между максимальным и минимальным элементами C++
Вычислить сумму отрицательных элементов массива и произведение элементов, расположенных между максимальным и минимальным элементами C++
В одномерном массиве вычислить сумму отрицательных элементов, произведение элементов массива между максимальным и минимальным элементами C++
Одномерный массив. Найти произведение элементов массива, расположенных между максимальным и минимальным элементами C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
asics
Freelance
Эксперт C++
 Аватар для asics
2838 / 1775 / 144
Регистрация: 09.09.2010
Сообщений: 3,842
03.12.2010, 23:18     В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива #2
Думаю понимаеш как внедрить это в свою програму
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 <stdio.h>
 
int get_sum(int arr[], const int N)
{
    int ind_min = 0, ind_max = 0, sum = 0;
 
    for(int i = 0; i < N; ++i)
    {
        if(arr[ind_min] > arr[i])
            ind_min = i;
        else if(arr[ind_max] < arr[i])
            ind_max = i;
    }
 
    for(int i = ind_min + 1; i < ind_max; ++i)
        sum += arr[i];
 
    return sum;
}
 
int main()
{
    const int N = 5;
    int arr[N] = {3, 1, 5, 8, 10};
    printf("Sum\n\t-> %d", get_sum(arr, N));
    return 0;
}
ka4ok73
1 / 1 / 0
Регистрация: 22.03.2010
Сообщений: 18
03.12.2010, 23:40  [ТС]     В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива #3
Извиняюсь, но не получается, и у вас в коде массив дан, а мне надо чтоб я его либо сам вводил, либо случайным образом, либо из файла, в общем как у меня в коде.
asics
Freelance
Эксперт C++
 Аватар для asics
2838 / 1775 / 144
Регистрация: 09.09.2010
Сообщений: 3,842
03.12.2010, 23:57     В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива #4
ka4ok73, Я же написАл функцию для нахождения сумы елементов между мин и макс, просто вставте ее в свой код.
Подправил чтобы функция принимала в качестве одного из аргументов не масив, а указатель на него.
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
int get_sum(int *arr, int N)
{
    int ind_min = 0, ind_max = 0, sum = 0;
 
    for(int i = 0; i < N; ++i)
    {
        if(arr[ind_min] > arr[i])
            ind_min = i;
        else if(arr[ind_max] < arr[i])
            ind_max = i;
    }
 
    for(int i = ind_min + 1; i < ind_max; ++i)
        sum += arr[i];
 
    return sum;
}
Теперь в своем коде просто напишите
C
1
printf("Sum\n\t-> %d", get_sum(Arr, n));
ka4ok73
1 / 1 / 0
Регистрация: 22.03.2010
Сообщений: 18
04.12.2010, 01:05  [ТС]     В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива #5
Спасибо за помощь, премного благодарен)

Добавлено через 12 минут
Не сразу заметил ошибки! в половине случаев считает, в половине нет, попробуйте сами у себя эту программу несколько раз запустить, во всём убедитесь сами. Если можно склейте свой код со своим, чтоб уж наверняка.
asics
Freelance
Эксперт C++
 Аватар для asics
2838 / 1775 / 144
Регистрация: 09.09.2010
Сообщений: 3,842
04.12.2010, 01:13     В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива #6
ka4ok73, Ну и в каких случаях не считает, привидите пример.
ka4ok73
1 / 1 / 0
Регистрация: 22.03.2010
Сообщений: 18
04.12.2010, 01:16  [ТС]     В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива #7
Ввожу с клавиатуры массив 100 5 6 1 8 Выводит сумму ноль, как я понял, если сначала идёт максимальный элемент, а потом минимальны, то не считает, если же наоборот, то всё нормально
asics
Freelance
Эксперт C++
 Аватар для asics
2838 / 1775 / 144
Регистрация: 09.09.2010
Сообщений: 3,842
04.12.2010, 01:28     В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива #8
Цитата Сообщение от ka4ok73 Посмотреть сообщение
как я понял, если сначала идёт максимальный элемент, а потом минимальны, то не считает, если же наоборот, то всё нормально
Вы все правильно поняли.
ka4ok73
1 / 1 / 0
Регистрация: 22.03.2010
Сообщений: 18
04.12.2010, 01:32  [ТС]     В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива #9
Можете исправить?
asics
Freelance
Эксперт C++
 Аватар для asics
2838 / 1775 / 144
Регистрация: 09.09.2010
Сообщений: 3,842
04.12.2010, 01:45     В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива #10
ka4ok73,
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
int get_sum(int *Arr, int N)
{
    int ind_min = 0, ind_max = 0, sum = 0;
 
    for(int i = 0; i < N; ++i)
    {
        if(arr[ind_min] > arr[i])
            ind_min = i;
        else if(arr[ind_max] < arr[i])
            ind_max = i;
    }
 
    if(ind_min < ind_max)
    {
        for(int i = ind_min + 1; i < ind_max; ++i)
            sum += arr[i];
    }
    else
    {
        for(int i = ind_max + 1; i < ind_min; ++i)
            sum += arr[i];
    }
 
    return sum;
}
ka4ok73
1 / 1 / 0
Регистрация: 22.03.2010
Сообщений: 18
04.12.2010, 01:49  [ТС]     В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива #11
Спасибо, очень помогли, спасибо большое!
ann312
0 / 0 / 0
Регистрация: 04.12.2014
Сообщений: 18
04.12.2014, 19:09     В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива #12
а для c++ кто-нибудь может помочь с кодом?
tiger97
3 / 3 / 2
Регистрация: 21.10.2014
Сообщений: 49
04.12.2014, 19:32     В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива #13
Тут помогают всем, создайте тему с заданием и просто ждите)
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
04.12.2014, 19:52     В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива
Еще ссылки по теме:

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

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

Или воспользуйтесь поиском по форуму:
ann312
0 / 0 / 0
Регистрация: 04.12.2014
Сообщений: 18
04.12.2014, 19:52     В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива #14
tiger97, спасибо за помощь неразобравшемуся новичку
Yandex
Объявления
04.12.2014, 19:52     В массиве А найти сумму элементов, расположенных между минимальным и максимальным элементами массива
Ответ Создать тему
Опции темы

Текущее время: 19:52. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru