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

Сам ассистанс гайс - C++

Восстановить пароль Регистрация
 
deerintheforest
0 / 0 / 0
Регистрация: 26.12.2013
Сообщений: 2
26.12.2013, 20:46     Сам ассистанс гайс #1
При работе программы вылетает ошибка
Необработанное исключение по адресу 0x00DD5061 в projectX.exe: 0xC0000005: нарушение прав доступа при чтении по адресу 0x00000000.
Происходит после вывода матрицы смежности на экран
Заранее спасибо за помощь
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
118
119
120
121
#include <conio.h>
#include <iostream>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
 
class Graph {
private:
    static int const NumberNodeDef = 10;
    static int const MaxNumNode = 15;
    int** matrix;
    int** matrixDist;
    int numnode;
    void createGraph();
    void showMatr(int**);
    void creatematrDist();
public:
    Graph();
    Graph(int);
    void showmatrix();
    void makematrixDist();
    void generateDist();
    void showmatrixDist();
};
 
Graph::Graph() : numnode(NumberNodeDef) {
    createGraph();
}
 
Graph::Graph(int innum) {
    if (innum <= MaxNumNode && innum>1) {
        numnode = innum;
    }
    else {
        numnode = NumberNodeDef;
    }
    createGraph();
}
 
void Graph::createGraph() {
    printf("zapolnite tablicu smejnosti (1/0)\n");
    matrix = new int*[numnode];
    for (int i = 0; i<numnode; i++) {
        matrix[i] = new int[numnode];
        for (int j = 0; j<numnode; j++) {
            printf("\nvvedite a[%d][%d]=", (i + 1), (j + 1));
            /*if(i==j) {
            matrix[i][j]=0;
            printf("0");
            }
            else {*/
            scanf_s("%d", &matrix[i][j]);
            //}
        }
    }
}
 
void Graph::creatematrDist() {
    int i, j;
    matrixDist = new int*[numnode];
    for (i = 0; i<numnode; i++) {
        matrixDist[i] = new int[numnode];
        for (j = 0; j<numnode; j++) {
            matrixDist[i][j] = 0;
        }
    }
}
 
void Graph::generateDist() {
    int i, j;
    for (i = 0; i<numnode; i++) {
        for (j = 0; j<numnode; j++) {
            if (matrix[i][j] == 1) {
                matrixDist[i][j] = rand() % 10;
            }
        }
    }
}
 
void Graph::makematrixDist() {
    int i, j, k;
    for (k = 0; k<numnode; k++) {
        for (i = 0; i<numnode; i++) {
            for (j = 0; j<numnode; j++) {
                if (matrixDist[i][j]>matrixDist[i][k] + matrixDist[k][j]) matrixDist[i][j] = matrixDist[i][k] + matrixDist[k][j];
            }
        }
    }
}
 
void Graph::showmatrix() {
    printf("Matrica smejnosti:\n");
    showMatr(matrix);
}
 
void Graph::showmatrixDist() {
    printf("Matrica rasstoyanij:\n");
    showMatr(matrixDist);
}
 
void Graph::showMatr(int **matr) {
    int i, j;
    for (i = 0; i < numnode; i++) {
        for (j = 0; j < numnode; j++){
            printf("%d ", matr[i][j]);
        }
    }
}
 
int main() {
    srand((unsigned)time(NULL));
    int innumnode;
    printf("vvedite kolichestvo vershin\n");
    scanf_s("%d", &innumnode);
    Graph gr(innumnode);
    gr.showmatrix();
    gr.generateDist();
    gr.makematrixDist();
    gr.showmatrixDist();
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.12.2013, 20:46     Сам ассистанс гайс
Посмотрите здесь:

N человек,сам незнаю как делается?! C++
C++ проверка чётности (сам не умею)
C++ Пользователь сам выбирает файл
Код выводит сам себя C++
C++ Кто сам выучил С++
С++ не могу сам сделать C++
Файл инклюдид сам себя C++
C++ сам не могу разобраться с ::operator new()

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

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

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