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

Вычыслить сумму между двумя первыми положительными элементами матрицы - C++

Восстановить пароль Регистрация
 
joemcjoe
0 / 0 / 0
Регистрация: 09.11.2013
Сообщений: 26
18.05.2014, 19:38     Вычыслить сумму между двумя первыми положительными элементами матрицы #1
Кликните здесь для просмотра всего текста
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
#include <iostream>
#include <ctime>
#include <cstdlib>
 
using namespace std;
 
template<class Type, int size> class Matrix;
 
template<class Type, int size>
ostream& operator << ( ostream& out, Matrix<Type,size> object);
 
template<class Type, int size>
class Matrix
{
    friend ostream& operator << <> ( ostream& out, Matrix<Type,size> object);
private:
    Type matrix[size][size];
public:
    Matrix();
    void RandomFill();
    Type sumbeetween();
};
 
template<class Type,int size>
Matrix<Type,size>::Matrix()
{
    for(int i=0;i<size;i++)
        for(int j=0;j<size;j++)
            matrix[i][j]=0;
}
 
 
template<class Type,int size>
void Matrix<Type,size>::RandomFill()
{
    Type randomNumber;
    for(int i=0;i<size;i++) 
    {
        for(int j=0;j<size;j++)
        {
            randomNumber=-5+(rand()% ((100-1) *1 + 1))/Type(10);
            matrix[i][j]=randomNumber;
        }
    }
 
 
}
 
 
template<class Type,int size>
Type Matrix<Type,size>::sumbeetween()
{
    Type sum = 0 ;
    int flag1,flag2;
    for(int i=0;i<size;i++) {
        for(int j=0;j<size;j++)
            if(matrix[i][j]>0) {
                flag1=i;
                flag2=j;
                break;
            }
    }
    int r=flag1,w=flag2;
    int flag3,flag4;
    for(flag1;flag1<size;flag1++) {
        for(flag2;flag2<size;flag2++) {
            if(matrix[flag1][flag2]>0) {
                flag3=flag1;
                flag4=flag2;
                break;
            }
        }
    }
 
    for(r;r<flag3;r++)
        for(w;w<flag4;w++)
            sum = sum + matrix[r][w];
 
    
 
    return sum;
            
                
            
 
}
 
 
 
 
 
template<class Type,int size>
 
ostream& operator << ( ostream& out, Matrix<Type,size> object)
{
    for (int i=0;i<size;i++,out << endl) {
        for(int j=0;j<size;j++) {
            out.width(4);
            out << object.matrix[i][j] << "   ";
            out.width(4);
        }
    }
    return out;
 
}
int main()
{
    srand(time(NULL));
    Matrix<double,10> matrix;
    cout << matrix << endl ;
    matrix.RandomFill();
    cout << matrix << endl << matrix.sumbeetween();
 
 
 
    return 0;
}


Помогите разобратся в функции sumbeetween(), она возвращает нуль почему-то.

Добавлено через 6 минут
Тему можна закрывать.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.05.2014, 19:38     Вычыслить сумму между двумя первыми положительными элементами матрицы
Посмотрите здесь:

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

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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