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

Экзамен - C++

Восстановить пароль Регистрация
 
Conroex
35 / 34 / 1
Регистрация: 20.04.2010
Сообщений: 126
11.06.2010, 14:12     Экзамен #1
3аданный миссив целых чисел делится на 3 части двумя элементами: максимальным и минимальным. Определить сумму элементов в каждой частьи масива. Используйте функции для нахождения индексов минимального и максимального элемента и подсчета суммы элементов в указаной части массива. ребята, пожалуйта помогите. Решить на самом примитивном уровне.

Добавлено через 35 минут
Ребята, пожалуйта, помогите. Сижу на экзамене не знаю что писать
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.06.2010, 14:12     Экзамен
Посмотрите здесь:

Экзамен по С C++
экзамен по с++ C++
C++ Экзамен
C++ Экзамен по C
C++ Экзамен.
Экзамен по С++ C++
Определить иерархию классов для варианта "тест, экзамен, выпускной экзамен, испытание" C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
NNN777
299 / 157 / 19
Регистрация: 27.02.2010
Сообщений: 317
11.06.2010, 16:04     Экзамен #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
#include <iostream>
using namespace std;
const int sz=20;
int nmin(int *, int);
int nmax(int *, int);
int ssumma (int *, int, int);
void main()
{
 
    int a[sz], i, n, k=0, l=0, sum1=0, sum2=0, sum3=0;
    cout<<"kolichestvo elementov: ";
    cin>>n;
    cout<<"Massiv: \n";
    for (i=0; i<n; i++)
        cin>>a[i];
    cout<<endl;
    k=nmin(a,n);
    l=nmax (a, n);
    if (k<l)
    {
        sum1=ssumma(a, 0, k);
        sum2=ssumma (a, k, l);
        sum3=ssumma (a, l, n);
    }
    else
    {
        sum1=ssumma(a, 0, l);
        sum2=ssumma (a, l, k);
        sum3=ssumma (a, k, n);
    }
    cout<<"sum1: "<<sum1<<"\nsum2: "<<sum2<<"\nsum3: "<<sum3<<endl;
}
int nmin(int *a, int n)
{
    int i, k=0, min;
    min=a[0];
    for (i=0; i<n; i++)
        if (a[i]<min)
        {
            min=a[i];
            k=i;
        }
        cout<<"min: "<<min<<" poziciy: "<<k<<endl;
    return k;
}
int nmax(int *a, int n)
{
    int max, i, l=0;
    max=a[0];
    for (i=0; i<n; i++)
        if (a[i]>max)
        {
            max=a[i];
            l=i;
        }
    cout<<"max: "<<max<<" poziciy: "<<l<<endl;
    return l;
}
int ssumma (int *m, int a, int b)
{
    int i, sum=0;
    for (i=a; i<b; i++)
        sum+=m[i];
    return sum;
}
Не предусмотрен ввод только одного элемента и одинаковых элементов
[Freeman]
34 / 34 / 6
Регистрация: 07.06.2010
Сообщений: 118
11.06.2010, 17:05     Экзамен #3
Опоздал не много ну раз написал то
вот:
Условия:
в суммы максимальный и минимальный элементы не считал(можно изменить)
массив максимум 30 элементов
без повторяющихся элементов
Сам проверил код полностью рабочий, правда не много большой
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
#include <iostream>
using namespace std;
const int arraySize=30;
int size;
//фукция для  нахождения индекса максимального элемента массива
int maxi(int arr[])
{
    int max=arr[0];
    int max_index=0;
    for(int i=0;i<size;i++)
    {
        if(arr[i]>max)
        {   
            max=arr[i];
            max_index=i;
        }
    }
    return max_index;
}
// функция для нахождения индекса минимального элемента массива
int mini(int arr[])
{
    int min=arr[0];
    int min_index=0;
    for(int i=0;i<size;i++)
    {
        if(arr[i]<min)
        {   
            min=arr[i];
            min_index=i;
        }
    }
    return min_index;
}
int summa(int arr[],int a,int b)
{
    int sum=0;
    for(int i=a;i<b;i++)
        sum+=arr[i];
    return sum;
}
int main()
{
    setlocale(0,"");
    cout<<"Количество элементов :";
    cin>>size;
    int arr[arraySize];
    cout<<"Элементы : "<<endl;
    for(int i=0;i<size;i++)
        cin>>arr[i];
    int max=maxi(arr);
    int min=mini(arr);
    for(int i=0;i<size;i++)
        cout<<arr[i]<<" ";
    cout<<endl<<"Индекс максимального элемета "<<max<<endl;
    cout<<"Индекс минимального элемента "<<min<<endl;
    int summ1=0,summ2=0,summ3=0;
    if(max>min)
    {
        ///1часть///min///2часть///max///3часть///
        summ1=summa(arr,0,min);
        summ2=summa(arr,min+1,max);
        summ3=summa(arr,max+1,size);
    }
    else
    {
        ///1часть///max///2часть///min///3часть///
        summ1=summa(arr,0,max);
        summ2=summa(arr,max+1,min);
        summ3=summa(arr,min+1,size);
    }
    cout<<"Сумма 1 части = "<<summ1<<endl;
    cout<<"Cумма 2 части = "<<summ2<<endl;
    cout<<"Сумма 3 части = "<<summ3<<endl;
    return 0;
}
Yandex
Объявления
11.06.2010, 17:05     Экзамен
Ответ Создать тему
Опции темы

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