0 / 0 / 1
Регистрация: 17.11.2015
Сообщений: 42

Ошибка при компилировании

27.11.2015, 20:10. Показов 524. Ответов 4
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Доброго дня! Уважаемые знатоки, помогите пожалуйста найти ошибку.
Пишу программу на С++ Builder "калькулятор матриц", которая должна умножать и складывать матрицы или матрицу и число. Матрицы делаю посредством StingGrid. Сейчас делаю процедуру умножения и при компиляции у меня запускается окно формы, я генерю обе матрицы, выбираю что множу 2ю матрицу, а не число, жму умножить, выходит ошибка
" is not a valid integer value.
Конкретно ругается на строку

C++
1
    summ+=StrToInt(StringGrid1->Cells[c] [m]) * StrToInt(StringGrid2->Cells[x] [c]);
Я на начальном этапе познаний С++, потому сильно не ругайтесь, сам чую ошибка глупая...
Ниже код всей программы (пока черновой естественно), а так же окно формы для наглядности.

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
//---------------------------------------------------------------------------
 
#include <vcl.h>
#pragma hdrstop
 
#include "MatrixCalc.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm1 *Form1;
int m, n, x, y, i, j;
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
        : TForm(Owner)
{
}
//---------------------------------------------------------------------------
 
void __fastcall TForm1::Button3Click(TObject *Sender)
{
    if ( ( TryStrToInt( Edit1->Text, m ) && TryStrToInt( Edit2->Text,
        n ) ) )
    {
 
        StringGrid1->RowCount = m;
        StringGrid1->ColCount = n;
 
        for ( int i = 0; i < m; i++ )
        {
            for ( int j = 0; j < n; j++ )
            {
                StringGrid1->Cells[ j ][ i ] = random( 200 ) -99;
            }
        }
    }
else
        {
         ShowMessage("Ошибка! введите число");
        }
}
//---------------------------------------------------------------------------
void __fastcall TForm1::Button4Click(TObject *Sender)
{
    if ( ( TryStrToInt( Edit3->Text, x ) && TryStrToInt( Edit4->Text,
        y ) ) )
    {
 
        StringGrid2->RowCount = x;
        StringGrid2->ColCount = y;
 
        for ( int i = 0; i < x; i++ )
        {
            for ( int j = 0; j < y; j++ )
            {
                StringGrid2->Cells[ j ][ i ] = random( 200 ) -99;
            }
        }
    }
else
        {
         ShowMessage("Ошибка! введите число");
        }
}
//---------------------------------------------------------------------------
void __fastcall TForm1::Button2Click(TObject *Sender)
//Умножение
{
int c, summ;
if (RadioButton1->Checked)
        {
        TryStrToInt( Edit1->Text, m);
        TryStrToInt( Edit2->Text, n);
        TryStrToInt( Edit3->Text, x);
        TryStrToInt( Edit4->Text, y);
        if (n!=x)
                {
                ShowMessage("Ошибка! Матрицы несогласованы \nКоличество столбцов матрицы А должно быть равно количеству строк матрицы В");
                }
        else
                {
                for (i = 0; i < m; i++)
                    {
                    for (j = 0; j < x; j++)
                        {
                        summ = 0;
                        for (c = 0; c < x; c++)
                                {
                                summ+=StrToInt(StringGrid1->Cells[c] [m]) * StrToInt(StringGrid2->Cells[x] [c]);
                                StringGrid3->ColCount=summ;
                                StringGrid3->RowCount=summ;
                                StringGrid3->Height=summ*StringGrid1->DefaultRowHeight+10;
                                StringGrid3->Width=summ*StringGrid1->DefaultColWidth+10;
                                StringGrid3->Cells[j] [i]=IntToStr(summ);
                                }
                        }
                    }
                }
        }
 
}
//---------------------------------------------------------------------------
Миниатюры
Ошибка при компилировании  
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
27.11.2015, 20:10
Ответы с готовыми решениями:

Ошибка при компилировании
Когда снимаю галочку Project-&gt;Options-&gt;Packages-&gt;Build with runtime packages. Компилятор не хочет компилировать, и показывает эту...

Ошибка при компилировании
При компиляции проекта выскакивает ошибка с текстом: Assertion failed : targSum!=NULL, file C:\src\ilink\fixups.c, line 561 Люди...

Неизвестная ошибка при компилировании
#include &lt;vcl.h&gt; #pragma hdrstop #include &quot;math.h&quot; #include &quot;Unit1.h&quot; ...

4
 Аватар для Chertenok_n_13
219 / 125 / 99
Регистрация: 14.03.2011
Сообщений: 628
27.11.2015, 20:33
BReDD, одна из используемых ячеек либо пустая, либо имеет тип отличный от int
возможно Вы неправильно указали m и n и он выходит за пределы того, что Вы хотите, а там пустая ячейка.
0
0 / 0 / 1
Регистрация: 17.11.2015
Сообщений: 42
27.11.2015, 20:44  [ТС]
Chertenok_n_13, это понятно. Я пробовал "на пальцах" процедуру с счетчиками при умножении на листочке расписать и все равно не понял, на что программа ругается. Ладно, если бы матрицы не квадратные были сгенерированы... А удобств для выявления ошибок при компиляции кода пока тоже толком незнаю.
0
 Аватар для Chertenok_n_13
219 / 125 / 99
Регистрация: 14.03.2011
Сообщений: 628
27.11.2015, 20:50
BReDD,
Цитата Сообщение от BReDD Посмотреть сообщение
summ+=StrToInt(StringGrid1->Cells[c] [m]) * StrToInt(StringGrid2->Cells[x] [c]);
если ошибка вылазит тут, то надо искать подводные камни в c,m,x,c и на что они заставляют указывать.
Что бы это понять, проходите по шагам этот цикл и просмотривайте в какой момент возникла ошибка.

Добавлено через 1 минуту
ставьте точку остановы (красненькая такая точечка на поле), ctrl+F7 вводите, какие переменные хотите просмотреть, дойдя до этого места, программа остановится, и тогда вам в помощь F8.
0
0 / 0 / 1
Регистрация: 17.11.2015
Сообщений: 42
28.11.2015, 13:04  [ТС]
Chertenok_n_13, спасибо большое! Благодаря Вашим рекомендациям, удалось выявить ошибку. Сейчас матрицы умножаются правильно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
28.11.2015, 13:04
Помогаю со студенческими работами здесь

Ошибка при компилировании исправной программы: Access violation at address 501F084A in module 'vcl120.bpl'
Взываю ко всем умам форума!(( Недавно я здесь создавал тему про ошибку, возникающую при компилировании исправной программы. А ошибка такая:...

Ошибка при компилировании проекта. [Linker Fatal Error] Fatal: Unable to open file '*.OBJ'
Ребят, при компилировании проекта вылезает ошибка Fatal: Unable to open file 'ACPNG.OBJ' P.S. исходник проекта был куплен, а...

Ошибки при компилировании
int AI:: Generation (Flot *CPU, int col_ship, int col_deck) { int x1, y1, k, i, j; bool vertical = false, regen; do {

Неполный тип файла при компилировании x64
Добрый день, компилирую проект x64, и в папке дебаг, он не верно обозначает файлы но если под x32 все, нормально...может что то я где то...

Ошибка при компилировании
Приветствую, скачал visual studio 2010 профессиональную, создал проект win32 с кодом окна апи, ничего не менял, попытался запустить этот...


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

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

Новые блоги и статьи
Компиляция C++ с Clang API
NullReferenced 24.03.2025
Компиляторы обычно воспринимаются как черные ящики, которые превращают исходный код в исполняемые файлы. Мы запускаем компилятор командой в терминале, и вуаля — получаем бинарник. Но что если нужно. . .
Многопоточное программировани­е в C#: Класс Thread
UnmanagedCoder 24.03.2025
Когда запускается приложение на компьютере, операционная система создаёт для него процесс - виртуальное адресное пространство. В C# этот процесс изначально получает один поток выполнения — главный. . .
SwiftUI Data Flow: Передача данных между представлениями
mobDevWorks 23.03.2025
При первом знакомстве со SwiftUI кажется, что фреймворк предлагает избыточное количество механизмов для передачи данных: @State, @Binding, @StateObject, @ObservedObject, @EnvironmentObject и другие. . . .
Моки в Java: Сравниваем Mockito, EasyMock, JMockit
Javaican 23.03.2025
Как протестировать класс, который зависит от других сложных компонентов, таких как базы данных, веб-сервисы или другие классы, с которыми и так непросто работать в тестовом окружении? Для этого и. . .
Архитектурные паттерны микросервисов: ТОП-10 шаблонов
ArchitectMsa 22.03.2025
Популярность микросервисной архитектуры объясняется множеством важных преимуществ. К примеру, она позволяет командам разработчиков работать независимо друг от друга, используя различные технологии и. . .
Оптимизация рендеринга в Unity: Сортировка миллиона спрайтов
GameUnited 22.03.2025
Помните, когда наличие сотни спрайтов в игре приводило к существенному падению производительности? Время таких ограничений уходит в прошлое. Сегодня геймдев сталкивается с задачами совершенно иного. . .
Образование и практика
Igor3D 21.03.2025
Добрый день А вот каково качество/ эффективность ВУЗовского образования? Аналитическая геометрия изучается в первом семестре и считается довольно легким курсом, что вполне справедливо. Ну хорошо,. . .
Lazarus. Таблица с объединением ячеек.
Massaraksh7 21.03.2025
Понадобилась представление на экране таблицы с объединёнными ячейками. И не одной, а штук триста, и все разные. На Delphi я использовал для этих целей TStringGrid, и то, кривовато получалось. А в. . .
Async/await в Swift: Асинхронное программировани­е в iOS
mobDevWorks 20.03.2025
Асинхронное программирование долго было одной из самых сложных задач для разработчиков iOS. В течение многих лет мы сражались с замыканиями, диспетчеризацией очередей и обратными вызовами, чтобы. . .
Колмогоровская сложность: Приёмы упрощения кода
ArchitectMsa 20.03.2025
Наверное, каждый программист хотя бы раз сталкивался с кодом, который напоминает запутанный лабиринт — чем дальше в него погружаешься, тем сложнее найти выход. И когда мы говорим о сложности кода, мы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru