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

Ошибка в выводе данных - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Структуры: Ведомость расхода топлива на автобазам города http://www.cyberforum.ru/cpp-beginners/thread843650.html
Разработать программу для обработки сведения (см. варианты заданий). * Программа должна обеспечивать: ввод исходных данных сведения из консоли в массив, состоящий из нескольких экземпляров структуры; обработку и вывод данных согласно варианту задания; вывод на консоль любого из записей сведения по критерию совпадения значения одного из полей записи данным запроса, вводится с консоли; вывод...
C++ Вывести отдельно «хорошистов» (оценки 4 и 5) для указанного извне класса 2.Дан список учащихся из 10 записей. Каждая запись имеет поля: фа-милия, имя, номер класса, оценки по трем предметам:вывести отдельно «хорошистов» (оценки 4 и 5) для указанного извне класса; Не могли бы вы помочь) http://www.cyberforum.ru/cpp-beginners/thread843634.html
C++ Латинские квадраты
Латинский квадрат. Латинским квадратом порядка n называется квадратная таблица размером nxn каждая строка и каждый столбец которой содержит все числа от 1 до n. Вводятся два числа n и k (n<=5, k<=20). Нужно построить k различных латинских квадратов размером nxn. Построение латинского квадрата более менее понятно, но не понимаю как задать оптимально функцию, чтобы строились именно различные k...
C++ Модульность. Программа, ссылающаяся на другую (как реализовать?)
Здравствуйте! Пишу курсовую, собственно уже все готово (тьфу тьфу тьфу), есть две программы, меню и игра, Из меню я вызываю всякие подпункты, один из них игра - это около 300-400 строк кода, я не хочу стаскивать все в один файл. Но суть такая, что после выполнения игры, я должен вернуться в основную программу, то есть в меню. Я не понимаю как реализовать такой процесс. В паскале можно было...
C++ Хеширование http://www.cyberforum.ru/cpp-beginners/thread843587.html
помогите пожалуйста дописать выгрузку хеш-таблицы в тот же файл! #include <vcl.h> #include<iostream.h> #include<fstream.h> #include<conio.h> #define n 12 #pragma hdrstop struct Tovar {
C++ Алгоритм определения планарности графа Задача: определить планарность графа, заданного списком смежности. Натолкните на истинный код, заранее признателен подробнее

Показать сообщение отдельно
Lubarshuks
0 / 0 / 0
Регистрация: 03.10.2012
Сообщений: 16
20.04.2013, 21:18     Ошибка в выводе данных
Вообщем код длинный , локализацию проблемы примерно знаю.
при выводе последнего результата выводиться мусор , кроме тех элементов , что присутствуют , прошу помочь , ибо не знаю как решить , Способ решения проблемы , указать , заранее огромное спасибо.
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
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
#include "stdafx.h"
#include <conio.h>
#include <iostream>
#include <iomanip>
#include <time.h>
using namespace std;
const size_t intsize = sizeof(int);
 
int** EnterMatrixFromFile(const char* fileName, int &row, int &col){
    
    FILE* file = fopen(fileName,"rb");
    if(file==NULL) return NULL;
    fread(&row,intsize,1,file);
    fread(&col,intsize,1,file);
    int** data = new int*[row];
    for(int i=0; i < row; i++){
        data[i]=new int[col];
        for(int j = 0; j < col; j++){
            fread(&data[i][j],intsize,1,file);
        }
    }
    fclose(file);
    return data;
}
 
bool SaveMatrixToFile(const char* fileName, int** matrix, int row, int col){
    FILE* file = fopen(fileName,"wb");
    if(file==NULL)return false;
    fwrite(&row,intsize,1,file);
    fwrite(&col,intsize,1,file);
    for(int i=0; i<row; i++)
        for(int j = 0; j < col; j++){
            fwrite(&matrix[i][j],intsize,1,file);
        }
    fclose(file);
    return true;
}
 
void EnterMatrixA(int **A, int row, int col ,int randRange)
{
    
    for (int i=0 ; i<row ; i++)
    {
        for (int j=0;j<col;j++)
        {
        
            cin>>A[i][j];
            
            }
            
        }
 
    return;
}
 
void PrintMatrixA(int **A , int row, int col )
{
    
    for (int i=0 ; i<row ; i++)
    {
        for (int j=0;j<col;j++)
        {
            cout<< A[i][j]<<" ";
            
        }
        cout<<endl;
}
    
    return;
}
 
void EnterMatrixB(int **B, int row, int col ,int randRange )
{
    
    srand(time(NULL));
    for (int i=0 ; i<row ; i++)
    {
        for (int j=0;j<col;j++)
        {
        
            B[i][j]=rand()%randRange;
            
        }
}
    
    return;
}
 
void PrintMatrixB (int **B, int row, int col )
{
    for (int i=0 ; i<row ; i++)
    {
        for (int j=0;j<col;j++)
        {
     
            cout<< B[i][j]<<" ";
            
        }
        cout<<endl;
}
    return;
}
 
double Calculate (int **A,int row)
{
    double sr = 0;
    for(int i=0;i<row;i++)
        {
            sr += A[i][i];
        }
    sr = sr / row;
    return sr;
}
 
int CompareSRAmatrixA(double srA,int **A,int row,int col, int *&arr)
//int* CompareSRAmatrixA(double srA,int **A,int row,int col, int &count)
{
 
    int c = 0, z = 0;
        
 
 for (int i=0;i<row;i++){
     for (int j=0; j<col; j++){
         if (srA<=A[i][j]){
             c++;
         }
     }
 }
 arr = new int[c];
 
 for (int i=0;i<row;i++){
     for (int j=0; j<col; j++){
         if (srA<=A[i][j]){
             
             arr[z++] = A[i][j];
        
         }
     }
 }
 /*for (int i=0;i<z;i++){
 
     cout<<arra[i]<<" ";
 }*/
 return c;
}
int CompareSRBmatrixB(int srB,int **B,int row,int col)
{
 
    int c = 0, z = 0 , g=0;
    
    for (int i=0;i<row;i++){
        for (int j=0; j<col; j++){
            if (srB<=B[i][j]){
                c++;
            }
        }
    }
    int *arra = new int[c];
 
    for (int i=0;i<row;i++){
        for (int j=0; j<col; j++){
            if (srB<=B[i][j]){
 
                arra[z] = B[i][j];
                z++;
            }
        }
    }
          
    
    for (int i=0;i<z;i++){
              
        cout<<arra[i]<<" ";
        }
 
    return *arra;
    
 
}
int main()
 
{
 
 
    setlocale(0,"Rus");
// Создание бинарного файла , которіый будет использован для счититывания информации из файла
    int r,c;
    int** myMatr = EnterMatrixFromFile("3.bin",r,c);
 
    PrintMatrixA(myMatr,r,c);
    
    int mainArray=0;
    double srA=0;
    double srB=0;
 
    int m=0;
    int n=0;
    int randRange=0;
 
    
    do{
    cout<<"Введите колличесвто строк и столбцов матрицы";
    cin>>m>>n;
    }while((m<0)||(n<0));
 
    cout<<endl;
    do {
    cout<<"Введите диапазон значений произвольно задаваемых значение в массиве ";
    cin>>randRange;
    }while(randRange<0);
    
       /* P.1.1Выделение памяти для матрицы .*/
    int *R = new int [200];
    int** A = new int*[m];
    for(int i = 0; i < m; i++) A[i] = new int[n];
        /*P.1.1Выделение памяти для матрицы .*/
    int** B = new int*[m];
    for(int i = 0; i < m; i++) B[i] = new int[n];
 
    cout <<"Matrix A : "<<endl;
          /*Р 1.2 Заполнение матрицы 1.*/
    //P.2.1 Ввод матрицы  А c клавиатуры
    EnterMatrixA(A,m,n,randRange);
    
     //P.2.2 Вывод исходной матрицы на монитор
    PrintMatrixA(A,m,n);
    //Запись информации о произвольно созданой матрици и запись самой матрици в файл , для даальнейшего ее использования.
    SaveMatrixToFile("3.bin",A,m,n);
    //P.1.3 Заполнение матрицы 2.
 
    
    cout<<" Matrix B  "<<endl;  
        //P.3.1 Ввод матрицы B произвольно
    EnterMatrixB(B,2,2,randRange);
        //P.3.2 Вывод исходной матрицы на монитор
    PrintMatrixB(B,2,2);
 
    //P.1.4Подсчеты .
 
      //P.4.1Подсчет среднего арифметического на диагонали матрицы 1
     srA = Calculate(A,2);
      // P.4.1Подсчет среднего арифметического на диагонали матрицы 2
     srB = Calculate(B,2);
 
     //Вывод среднего арифметического матриц А и В.
        cout<<"Среднее арифметическое дигонали матрици А : "<<srA<<endl;
        cout<<"Среднее арифметическое дигонали матрици B : "<<srB<<endl;
        cout<<endl<<endl;
        cout<<"Требуемый результат : ";
        //P.1.5 Сравнениие . 
        //P.5.1 Сравнение среднего арифмитического  элементов матрицы 1 с элементами матрици2
 
        int *Arr1=NULL;
        int count1=0,count2=0;
        int *Arr2=NULL;
        
        count1 = CompareSRAmatrixA(srA,A, 2, 2, Arr1);
        count2 = CompareSRAmatrixA(srB,B, 2, 2, Arr2);
        //P.5.2 Сравнение среднего арифмитического  элементов матрицы 2 с элементами матрици1
//      Arr2 = CompareSRBmatrixB(srB,B, 2, 2);
        int* Result=NULL;
        int totalSize =count1+count2;
        Result = new int [count1+count2];
 
        memcpy((void *)Result,(void *)Arr1, sizeof(int)*count1);
        memcpy((void *)(Result+sizeof(int)*count1), (void *)Arr2, sizeof(int)*count2);
  
 for (int i=0; i<totalSize; i++)
 {
     cout<<Result[i]<<"\t";
 }
 
  
    getch ();
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 18:37. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru