Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
zmei87
0 / 0 / 0
Регистрация: 27.10.2013
Сообщений: 10
#1

Не могу найти ошибку

27.10.2013, 13:18. Просмотров 340. Ответов 9
Метки нет (Все метки)

Доброго времени суток, вообщем такое задание:
В одномерном массиве,состоящем из n вещественных элементов вычислить:
1. Произведение положительных элементов массива;
2.Сумму элементов массива, расположенных до минимального элемента.
3.Упорядочить по возрастанию отдельно элементы, стоящие на четных местах, и элементы, стоящие на нечетных местах. (n вводится с клавиатуры)

написал код, но выполняется только тритий пункт,первые 2 ну никак не хотят выполняться =( исправьте пожалуйста код или подскжажите где ошибка

Код
#include "iostream.h"
using namespace std;

int _tmain(int argc, _TCHAR* argv[])
{
	cout << "Enter size of array: ";
	int ArrSize;
	cin >> ArrSize;

	double *arr = new double[ArrSize];
	int i;

	double multPlus = 1.0;	// произведение положительных элементов

							// заполняем массив
	for (i=0; i<ArrSize; i++)
	{
		cout << "arr[" << i << "] = ";
		cin >> arr[i];
		
		if (arr[i] > 0)
			multPlus *= arr[i];
	}

	double min = arr[0];	// минимальный элемент массива
	int minCol;

	for (i=1; i<ArrSize; i++)
		if (arr[i] < min)
		{
			min = arr[i];
			minCol = i;
		}

	double summ = 0.0;		// сумма элементов массива до минимального

	for (i=0; i<minCol; i++)
		summ += arr[i];


	bool t = true;
	double temp;

	// сортировка на нечетных местах
	while (t)
	{
		t = false;
		for (i=1; i<ArrSize-2; i += 2)
			if (arr[i] > arr[i+2])
			{
				temp = arr[i];
				arr[i] = arr[i+2];
				arr[i+2] = temp;

				t = true;
			}
	}

	// сортировка на четных местах
	t = true;
	while (t)
	{
		t = false;
		for (i=0; i<ArrSize-2; i += 2)
			if (arr[i] > arr[i+2])
			{
				temp = arr[i];
				arr[i] = arr[i+2];
				arr[i+2] = temp;

				t = true;
			}
	}

	for (i=0; i<ArrSize; i++)
		cout << arr[i] << "  ";




	delete [] arr;

	cin.get();
	cin.get();
	return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
27.10.2013, 13:18
Ответы с готовыми решениями:

Найти слова, повторяющиеся более одного раза, не могу найти ошибку
#include &lt;iostream&gt; using namespace std; void obr1(char **s, char **mas,...

Массивы. Посчитать количество положительных, найти минимальное, удалить строку с минимальным (Не могу найти ошибку)
// Заданы матрицы X(8;4),Y(5;5),Z(6;9). // Для каждой из матриц определить...

Не могу найти ошибку
Вот операция void int z; void min(int x1,int x2) { if (x1&gt;=x2) x1-=x2;...

Не могу найти ошибку
Добрый день, программа не компилируется, не могу найти ошибку. Заранее спасибо....

Не могу найти ошибку
#include &quot;stdafx.h&quot; #include &lt;conio.h&gt; class Sum { public: int sum1...

9
justDo
8 / 8 / 0
Регистрация: 06.10.2013
Сообщений: 19
27.10.2013, 13:28 #2
Цитата Сообщение от zmei87 Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
10
11
double multPlus = 1.0;  // произведение положительных элементов
 
                            // заполняем массив
    for (i=0; i<ArrSize; i++)
    {
        cout << "arr[" << i << "] = ";
        cin >> arr[i];
        
        if (arr[i] > 0)
            multPlus *= arr[i];
    }
вот вы посчитали произведение, а вывести на экран забыли?
судя по всему, то же самое со вторым пунктом, сделать сделали, а данные не вывели, а третий пункт их уже изменил
2
zmei87
0 / 0 / 0
Регистрация: 27.10.2013
Сообщений: 10
27.10.2013, 13:31  [ТС] #3
Цитата Сообщение от justDo Посмотреть сообщение
вот вы посчитали произведение, а вывести на экран забыли?
судя по всему, то же самое со вторым пунктом, сделать сделали, а данные не вывели, а третий пункт их уже изменил
если я не ошибаюсь вывод на экран cout 0?
0
justDo
8 / 8 / 0
Регистрация: 06.10.2013
Сообщений: 19
27.10.2013, 13:34 #4
Цитата Сообщение от zmei87 Посмотреть сообщение
если я не ошибаюсь вывод на экран cout 0?
где в вашем коде выводится, допустим, multPlus?
0
henecs
18 / 18 / 11
Регистрация: 19.05.2013
Сообщений: 135
27.10.2013, 13:37 #5
2й пункт можно сделать еще так
небольшие изменения в вашем коде
C++
1
2
3
4
5
6
7
8
9
10
11
int min = 0;    // минимальный элемент массива
 
    for (i=1; i<ArrSize; i++)
        if (arr[i] < arr[min])
            min = i;
 
    double summ = 0.0;      // сумма элементов массива до минимального
 
    for (i=0; i<min; i++)
        summ += arr[i];
    cout<<"summ = "<< summ; // ну и вывод
1
zmei87
0 / 0 / 0
Регистрация: 27.10.2013
Сообщений: 10
27.10.2013, 14:41  [ТС] #6
Цитата Сообщение от henecs Посмотреть сообщение
2й пункт можно сделать еще так
небольшие изменения в вашем коде
C++
1
2
3
4
5
6
7
8
9
10
11
int min = 0;    // минимальный элемент массива
 
    for (i=1; i<ArrSize; i++)
        if (arr[i] < arr[min])
            min = i;
 
    double summ = 0.0;      // сумма элементов массива до минимального
 
    for (i=0; i<min; i++)
        summ += arr[i];
    cout<<"summ = "<< summ; // ну и вывод
переписал ваш код, ничего не выходит, не могли бы вы скинуть мой код целый, только в исправленном виде
0
justDo
8 / 8 / 0
Регистрация: 06.10.2013
Сообщений: 19
27.10.2013, 14:52 #7
zmei87, просто сделайте вывод на экран значений
0
zmei87
0 / 0 / 0
Регистрация: 27.10.2013
Сообщений: 10
27.10.2013, 23:35  [ТС] #8
Цитата Сообщение от justDo Посмотреть сообщение
zmei87, просто сделайте вывод на экран значений
я вас чуть чуть не понимаю

Добавлено через 7 часов 59 минут
апп
0
henecs
18 / 18 / 11
Регистрация: 19.05.2013
Сообщений: 135
28.10.2013, 18:52 #9
как то так
Кликните здесь для просмотра всего текста
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
#include <iostream>
using namespace std;
 
int main()
{
    cout << "Enter size of array: ";
    int ArrSize;
    cin >> ArrSize;
 
    double *arr = new double[ArrSize];
 
    double multPlus = 1.0;  // произведение положительных элементов
 
                            // заполняем массив
    for (int i=0; i<ArrSize; i++)
    {
        cout << "arr[" << i << "] = ";
        cin >> arr[i];
        
        if (arr[i] > 0)
            multPlus *= arr[i];
    }
    cout<< "proizvedenie a [i]>0 = "<<multPlus<<endl;
 
    int min = 0;    // индекс мин элемента массива
 
    for (int i=1; i<ArrSize; i++)
        if (arr[i] < arr[min])
        {
            min = i;
        }
 
    double summ = 0.0;      // сумма элементов массива до минимального
 
    for (int i=0; i<min; i++)
        summ += arr[i];
    cout<< "summa = "<<summ<<endl;
 
    bool t = true;
    double temp;
 
    // сортировка на нечетных местах
    while (t)
    {
        t = false;
        for ( int i=1; i<ArrSize-2; i += 2)
            if (arr[i] > arr[i+2])
            {
                temp = arr[i];
                arr[i] = arr[i+2];
                arr[i+2] = temp;
 
                t = true;
            }
    }
 
    // сортировка на четных местах
    t = true;
    while (t)
    {
        t = false;
        for ( int i=0; i<ArrSize-2; i += 2)
            if (arr[i] > arr[i+2])
            {
                temp = arr[i];
                arr[i] = arr[i+2];
                arr[i+2] = temp;
 
                t = true;
            }
    }
 
    for (int i=0; i<ArrSize; i++)
        cout << "arr[" << i << "] = "<<arr[i]<<endl;
 
    delete [] arr;
 
    cin.get();
    cin.get();
    return 0;
}
1
zmei87
0 / 0 / 0
Регистрация: 27.10.2013
Сообщений: 10
28.10.2013, 20:28  [ТС] #10
Цитата Сообщение от henecs Посмотреть сообщение
как то так
Кликните здесь для просмотра всего текста
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
#include <iostream>
using namespace std;
 
int main()
{
    cout << "Enter size of array: ";
    int ArrSize;
    cin >> ArrSize;
 
    double *arr = new double[ArrSize];
 
    double multPlus = 1.0;  // произведение положительных элементов
 
                            // заполняем массив
    for (int i=0; i<ArrSize; i++)
    {
        cout << "arr[" << i << "] = ";
        cin >> arr[i];
        
        if (arr[i] > 0)
            multPlus *= arr[i];
    }
    cout<< "proizvedenie a [i]>0 = "<<multPlus<<endl;
 
    int min = 0;    // индекс мин элемента массива
 
    for (int i=1; i<ArrSize; i++)
        if (arr[i] < arr[min])
        {
            min = i;
        }
 
    double summ = 0.0;      // сумма элементов массива до минимального
 
    for (int i=0; i<min; i++)
        summ += arr[i];
    cout<< "summa = "<<summ<<endl;
 
    bool t = true;
    double temp;
 
    // сортировка на нечетных местах
    while (t)
    {
        t = false;
        for ( int i=1; i<ArrSize-2; i += 2)
            if (arr[i] > arr[i+2])
            {
                temp = arr[i];
                arr[i] = arr[i+2];
                arr[i+2] = temp;
 
                t = true;
            }
    }
 
    // сортировка на четных местах
    t = true;
    while (t)
    {
        t = false;
        for ( int i=0; i<ArrSize-2; i += 2)
            if (arr[i] > arr[i+2])
            {
                temp = arr[i];
                arr[i] = arr[i+2];
                arr[i+2] = temp;
 
                t = true;
            }
    }
 
    for (int i=0; i<ArrSize; i++)
        cout << "arr[" << i << "] = "<<arr[i]<<endl;
 
    delete [] arr;
 
    cin.get();
    cin.get();
    return 0;
}
спасибо огромное, выручили очень сильно тему можно закрывать
0
28.10.2013, 20:28
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
28.10.2013, 20:28

Не могу найти ошибку...
минимум среди сумм модулей элементов диагоналей, параллельных побочной...

Не могу найти ошибку
{ char str={0}; char str2={0}; int k=0; int n=8;...

Не могу найти ошибку
#include &lt;iostream&gt; #include &lt;cmath&gt; #define N = 3 using namespace std;...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru