Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 19.06.2013
Сообщений: 28

В матрице P(N;M) найти сумму элементов каждого столбца

25.12.2013, 16:28. Показов 897. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В матрице P(N;M) найти суму елементов каждого столбца!
есть программа не могу понять почему выбивает ошибку
помогите исправить пожалуйста!
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 <vcl.h>
#pragma hdrstop
 
#include "Unit1.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
class matrix
{int **p;
int *mas;
 public:
 matrix() {p=NULL;}
 ~matrix() {if(p)delete[]p;}
                if(mas)delete[]mas;}
 
 void formuv(int m,int n);
 int ruh(int m,int n);
 int get_p(int i2,int j2)
 {return p[i2][j2];}
 int get_q(int i2)
 {return mas[i2];}
 };
 
 matrix obj;
 
 void matrix::formuv(int m,int n)
 {int row=m;
  int col=n;
 if(p) delete[]p;
 p=new int *[m];
 int i,j;
 for(i=0;i<m;i++)
 p[i]=new int [n];
 for(i=0;i<m;i++)
 {for(j=0;j<n;j++)
 p[i][j]=random(50)-15;}}
 
 int matrix::ruh(int m,int n)
 {int row=m;
  int col=n;
  int *mas = new int[n];         
    for(int i = 0; i < row; i++)         
    {mas[i]=0;
        for(int j = 0; j < col; j++)
            mas[i]+=p[j][i];
           }}
 
TForm1 *Form1;
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
        : TForm(Owner)
{
}
 
//---------------------------------------------------------------------------
 
 
void __fastcall TForm1::Button1Click(TObject *Sender)
{int i,j;
 randomize();
 obj.formuv(StrToInt(Edit1->Text),StrToInt(Edit2->Text));
 StringGrid1->ColCount=StrToInt(Edit1->Text);
 StringGrid1->RowCount=StrToInt(Edit2->Text);
 for(i=0;i<StrToInt(Edit1->Text);i++)
 for(j=0;j<StrToInt(Edit2->Text);j++)
 StringGrid1->Cells[i][j]=IntToStr(obj.get_p(i,j));
}
//---------------------------------------------------------------------------
 
 
void __fastcall TForm1::Button2Click(TObject *Sender)
{
int n,m,i;
obj.ruh(m,n);
ListBox1->Clear();
for(int i=0;i<n;i++)
ListBox1->Items->Add(IntToStr(obj.get_q(i)));
}
//---------------------------------------------------------------------------
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.12.2013, 16:28
Ответы с готовыми решениями:

Определить сумму элементов каждого столбца левой половины и сумму элементов каждого четного столбца правой половины матрицы A
Матрица A (M кратно 4) разделена по вертикали на две половины. Определить сумму элементов каждого...

В прямоугольной матрице заменить элементы каждого столбца на сумму элементов этого столбца
Решить задачу: в прямоугольной матрице заменить элементы каждого столбца на сумму элементов этого...

В массиве 5х6 вывести на экран сумму элементов каждого четного столбца и произведение элем-тов каждого нечетного столбца
Задание:Найти в массиве 5х6 и вывести на экран сумму элементов каждого парного столбца и...

10
 Аватар для Kulgar
511 / 196 / 26
Регистрация: 07.08.2013
Сообщений: 814
25.12.2013, 16:35
mikis, какую ошибку?!

P.S.
Цитата Сообщение от Kulgar Посмотреть сообщение

Не по теме:

:wizard: Неа! :p
Хотя..... если ж это по форуму пойдёт, все кривые темы мне будут пересылаться... вроде штатного телепата. :scare: НЕТ! СПАСИБО! <отдал воображаемую шляпу и слинял куда подальше>

0
0 / 0 / 0
Регистрация: 19.06.2013
Сообщений: 28
25.12.2013, 17:52  [ТС]
C++
1
mas[i]+=p[j][i];
вот это не нравиться С++ в программе
0
 Аватар для Kulgar
511 / 196 / 26
Регистрация: 07.08.2013
Сообщений: 814
25.12.2013, 17:53
mikis, Вы имеете ввиду не нравится компилятору? Как его зовут?
И ещё вопрос: не нравится вкус? запах? цвет? может консистенция не та?..
0
0 / 0 / 0
Регистрация: 19.06.2013
Сообщений: 28
25.12.2013, 18:09  [ТС]
ну да компилятору
0
0 / 0 / 0
Регистрация: 19.06.2013
Сообщений: 28
25.12.2013, 18:16  [ТС]
вот кароче так..)
0
0 / 0 / 0
Регистрация: 19.06.2013
Сообщений: 28
26.12.2013, 19:37  [ТС]
Unit.rar
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33407 / 21517 / 8236
Регистрация: 22.10.2011
Сообщений: 36,917
Записей в блоге: 12
26.12.2013, 19:44
mikis, у тебя матрица создается так:
C++
1
2
3
4
 p=new int *[m];
 int i,j;
 for(i=0;i<m;i++)
 p[i]=new int [n];
, то есть, первый индекс изменяется от 0 до m-1, а второй - от 0 до n-1. Теперь смотри, что у тебя в коде происходит дальше:
C++
1
2
3
4
5
6
7
8
9
10
int row=m;
int col=n;
 
int *mas = new int[n];
for(int i = 0; i < row; i++)
{
   mas[i]=0;
   for(int j = 0; j < col; j++)
      mas[i]+=p[j][i]; // Вот тут !!!
}
, первый индекс - это j, который изменяется от 0 до col-1, то есть, до n-1... Если только n > m, то тут будет вылет за пределы массива. Со вторым индексом тоже напутано. В общем, ты их просто поменял местами...

То же самое касается и mas, разрешена индексация 0 .. n-1, а значение i в каких пределах будет изменяться, посмотри внимательно?
0
0 / 0 / 0
Регистрация: 19.06.2013
Сообщений: 28
26.12.2013, 19:50  [ТС]
А это я пробывал менял так и сяк...
но выбивает одно и тоже...
можешь код как правельно сбросить...
а то мозг кипит уже...
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33407 / 21517 / 8236
Регистрация: 22.10.2011
Сообщений: 36,917
Записей в блоге: 12
26.12.2013, 20:24
Цитата Сообщение от mikis Посмотреть сообщение
код как правельно
Вот так:

header
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
class TForm1 : public TForm
{
__published: // IDE-managed Components
 
    TLabel *Label1;
    TLabel *Label2;
    TEdit *Edit1;
    TEdit *Edit2;
    TStringGrid *StringGrid1;
    TButton *Button1;
    TButton *Button2;
    TListBox *ListBox1;
 
    void __fastcall Button1Click(TObject *Sender);
    void __fastcall Button2Click(TObject *Sender);
 
private: // User declarations
    int m, n; // <--- Вот эту строку добавляем !!!
 
public: // User declarations
    __fastcall TForm1(TComponent* Owner);
};
cpp-файл:
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
class matrix
{
    int **p;
    int *mas;
 
public:
    matrix()
    {
        p = NULL;
    }
 
    ~matrix()
    {
        if (p)
            delete[]p;
    }
 
    void formuv(int m, int n);
    void ruh(int m, int n);
 
    int get_p(int i2, int j2)
    {
        return p[i2][j2];
    }
 
    int get_q(int i2)
    {
        return mas[i2];
    }
};
 
matrix obj;
 
void matrix::formuv(int m, int n)
{
    if (p)
        delete[]p;
    p = new int *[m];
    int i, j;
    for (i = 0; i < m; i++)
        p[i] = new int[n];
    for (i = 0; i < m; i++)
    {
        for (j = 0; j < n; j++)
            p[i][j] = random(50) - 15;
    }
}
 
void matrix::ruh(int m, int n)
{
    mas = new int[n]; // Обрати внимание на изменения !!!
    for (int i = 0; i < n; i++)
    {
        mas[i] = 0;
        for (int j = 0; j < m; j++)
            mas[i] += p[j][i];
    }
}
 
TForm1 *Form1;
 
// ---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner) : TForm(Owner)
{
}
 
// ---------------------------------------------------------------------------
 
void __fastcall TForm1::Button1Click(TObject *Sender)
{
    randomize();
    obj.formuv(StrToInt(Edit1->Text), StrToInt(Edit2->Text));
    m = StrToInt(Edit1->Text);
    n = StrToInt(Edit2->Text);
 
    StringGrid1->RowCount = m;
    StringGrid1->ColCount = n;
    StringGrid1->FixedCols = 0;
    StringGrid1->FixedRows = 0;
    StringGrid1->DefaultColWidth = 25;
    for (int i = 0; i < m; i++)
        for (int j = 0; j < n; j++)
            StringGrid1->Cells[j][i] = IntToStr(obj.get_p(i, j));
 
}
// ---------------------------------------------------------------------------
 
void __fastcall TForm1::Button2Click(TObject *Sender)
{
    obj.ruh(m, n);
    ListBox1->Clear();
    for (int i = 0; i < n; i++)
        ListBox1->Items->Add(IntToStr(obj.get_q(i)));
 
}
1
0 / 0 / 0
Регистрация: 19.06.2013
Сообщений: 28
26.12.2013, 21:41  [ТС]
ААААА...
Надо мне было так тупить...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.12.2013, 21:41
Помогаю со студенческими работами здесь

В матрице найти сумму и количество элементов каждого столбца, которые являются простыми числами
В прямоугольной матрице размерностью n*m, заполненной случайным образом числами из промежутка ,...

Найти сумму элементов первого столбца без одного последнего элемента, сумму элементов второго столбца без двух последних...
Здравствуйте, форумчане! У меня вот такая вот задачка: Задан двумерный массив. Найти сумму...

Вычесть из каждого столбца матрицы максимальный элемент для каждого столбца, и результат вывести в матрицу
Что нужно добавить , чтобы вычесть из каждого столбца матрицы максимальный элемент для каждого...

Массив: В заданной матрице вычислить сумму элементов каждого столбца и записать результаты в одномерный массив.
Здравствуйте. Нужна помощь с двумерным массивом. В двумерном массиве вычислить сумму элементов...

Матрицы. Найти и распечатать сумму элементов 5-го столбца матрицы А и сумму элементов последней строки матрицы В
Даны две матрицы А(mxn)и В(m1xn1).программа находит и распечатывает сумму элементов 5-го столбца...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru