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

Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 11, средняя оценка - 4.91
Мила Хорошилова
0 / 0 / 0
Регистрация: 05.01.2013
Сообщений: 18
05.01.2013, 15:47     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент #1
всем привет) у меня проблема. мне нужно защиту от некорректного ввода. задание. Дана целочисленная матрица.
Уплотнить заданную матрицу, удаляя из нее строки и столбцы, заполненные нулями. Найти номер первой из строк, содержащих хотя бы один положительный элемент.нужно чтобы вводились целые числа от -10 до 10, enter, backspase. саму прогу могу скинуть. Заранее спасибо.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.01.2013, 15:47     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент
Посмотрите здесь:

Уплотнить заданную матрицу, удаляя из нее строки и столбцы, заполненные нулями C++
Уплотнить заданную матрицу, удаляя из нее строки и столбцы, заполненные нулями. Найти номер первой из строк, содержащих хотя бы один положительный эле C++
Уплотнить заданную матрицу, удаляя из нее строки и столбцы, заполненные нулями C++
Необходимо уплотнить заданную матрицу,удаляя из нее строки и столбцы, заполненные нулями C++
Уплотнить заданную матрицу, удаляя из нее строки и столбцы, заполненные нулями C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Андрей\
3 / 3 / 0
Регистрация: 13.12.2011
Сообщений: 22
05.01.2013, 15:56     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент #2
Вам нужен ввод чисел 0-9 и знак минус...Плюс прописать запрет на ввод знака минус после числа, чтобы предотвратить написание вроде 4-5.
Постараюсь к вечеру код выложить. Поправите, если что не так.
Мила Хорошилова
0 / 0 / 0
Регистрация: 05.01.2013
Сообщений: 18
05.01.2013, 16:18  [ТС]     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент #3
Цитата Сообщение от Андрей\ Посмотреть сообщение
Вам нужен ввод чисел 0-9 и знак минус...Плюс прописать запрет на ввод знака минус после числа, чтобы предотвратить написание вроде 4-5.
Постараюсь к вечеру код выложить. Поправите, если что не так.

да. вы правы. ну и энтер и блэкспэйс. )) буду очень благодарна за помощь))
Андрей\
3 / 3 / 0
Регистрация: 13.12.2011
Сообщений: 22
05.01.2013, 17:27     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент #4
Вот что получилось. Прошу не судить строго, так как писалось все давно. Если возникнут какие-то ошибки, пишите - поправлю.
P.S. Ах да, язык Си а не Си++, придется Вам самой немного исправлять...

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
#include "stdafx.h"
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include <locale.h>
#include <string.h>
#include <malloc.h>
 
 
int write(void) //ввод размерности(защита аналогичная требуемой, но в упрощенном варианте): комментарии в основной 
{
char str[5];
const int L=2;
char c;
int i=0;
bool flag=0, flug=0;
while( (c=_getch())!=13)
    {
if (((c==43)||(c==45))&&(i==0)&&(flug!=1)) 
    {
printf("%c",c);
str[i]=c;
i++;
str[i]='\0';
flug=1;
    }
if ((c==48)&&(i<L)&&(flag!=1)&&(i!=0)) 
    {
printf("%c",c);
str[i]=c;
i++;
str[i]='\0';
    }
if (((c>=49)&&(c<=57))&&(i<L)&&(flag!=1)) 
    {
printf("%c",c);
str[i]=c;
i++;
str[i]='\0';
    }
if ((c==8)&&(i>0))
    {
printf("\b \b");
i--;
str[i]='\0';
    }
if ( ((atoi(str)> 8)||(atoi(str)< 2))&&(i>0)) 
    {
    flag=1; 
printf("\b \b");
i--;
str[i]='\0';}
else flag=0;
    }
return atoi(str);
    }
 
 
int pro(void)//защита
{
char str[5];
char c;
int i=0, flag=0;
int b;
 
while( (c=_getch())!=13)
{
 
if ((c==43)&&(i==0))//первый +
{
printf("%c",c);
str[i]=c;
i++;
str[i]='\0';
}
 
if ((c==45)&&(i==0))//первый -
{
printf("%c",c);
str[i]=c;
i++;
str[i]='\0';
}
 
 
if (((c>=48)&&(c<=57))&&(i<3)&&(flag!=1))//цифры 0-9
{
printf("%c",c);
str[i]=c;
i++;
str[i]='\0';
}
 
if ((c==8)&&(i>0))//backspace
{
printf("\b \b");
i--;
str[i]='\0';
}
 
    if ((atoi(str)>10)||(atoi(str)<(-10))|| ((atoi(str)==48)&&(i==1)))//если не в диапазоне, удаляй
     {
    flag=1; 
printf("\b \b");
i--;
str[i]='\0';
     }
else flag=0;
}
b=atoi(str);
return b;
}
 
 
int **matrix(int nrow, int ncol) //динамическое выделение памяти матрицы А 
{
        int  i;
        int **p;
 
        p = (int **) calloc(nrow , sizeof(int *));
                        
        for (i = 0; i < nrow; i++)
               p[i] =(int *) calloc(ncol , sizeof(int));   
        return p;
}
 
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale(LC_ALL,"Russian");
    int **A;//матрица, защиту которой необходимо обеспечить
    int m;
    do
        {
    printf("Введите размерность матрицы ");
    printf("\n m = ");
        m=write();
        }
while (m>8 || m<2);
 
    A=matrix(m, m);
    for(int i=0;i<m;i++)
        {
    for(int j=0;j<m;j++)
        {
        printf("\nВведите  A[%d][%d]:    ",i+1,j+1);//ввод элементов
        A[i][j]=pro();//ваша матрица
        }
        }
    printf("\n");
    for(int i=0;i<m;i++)
        {
    for(int j=0;j<m;j++)
        {
       printf(" %3.1d", A[i][j]);//выравнивание
        }
        printf("\n");
        }
 
    _getch();
    return 0;
}
Мила Хорошилова
0 / 0 / 0
Регистрация: 05.01.2013
Сообщений: 18
05.01.2013, 17:48  [ТС]     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент #5
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
void  input_elements(int ***uA, int* uM, int* uN)
{
 
int **A, M, N, m, i, j;
 
do{
 
printf("  ********МЕНЮ******** \n"
       " 1) Заполнение матрицы с клавиатуры\n"
       " 2) Заполнение матрицы случайными числами\n"
       " 3) Заполнение матрицы из файла\n"
       " Ваш выбор : ");
m=zachita('m');
//scanf("%d", &m);
 
switch(m){
 
    case 1: 
 
        M=input("строка",'M');
        N=input("столбцов",'N');
        A=memory(M,N);
                 for(i=0; i<M; i++)
                 for(j=0; j<N; j++)
                 {
                   printf("Введите A[%d][%d]",i+1,j+1);
                   //A[i][j]=zachita('A[i][j]');  ??????
                   //scanf("%d", &A[i][j]);
                 }
 
 
            break;
 
    case 2:
        M=input("строка",'M');
        N=input("столбцов",'N');
        A=memory(M,M);
                 for(i=0; i<M; i++)
                 for(j=0; j<N; j++)
                 {
                   
                   A[i][j]=rnd(-10, 10 );
                 }
 
            break;



спасибо) я теперь и сама разобралась. меня интересует вот что. защита написана. надо ее использовать. как вставить ее при вводе а и-того жи-того. вот часть проги. как быть там где ???????. мне пишет ошибка.
Андрей\
3 / 3 / 0
Регистрация: 13.12.2011
Сообщений: 22
05.01.2013, 18:20     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент #6
Цитата Сообщение от Мила Хорошилова Посмотреть сообщение
спасибо) я теперь и сама разобралась. меня интересует вот что. защита написана. надо ее использовать. как вставить ее при вводе а и-того жи-того. вот часть проги. как быть там где ???????. мне пишет ошибка.
Ммм...Не знаю, често говоря сложно сообразить, возможно " scanf("%d", &A[i][j]);" лишнее...
Мила Хорошилова
0 / 0 / 0
Регистрация: 05.01.2013
Сообщений: 18
05.01.2013, 19:51  [ТС]     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент #7
да. лишнее. оно закомментированно. сканф вообще не нужны при использовании zachita(' '). вопрос в том что написать вместо А[i] [j] = zachita (' A[i] [j]')? потому что пишет ошибку
Андрей\
3 / 3 / 0
Регистрация: 13.12.2011
Сообщений: 22
05.01.2013, 19:55     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент #8
Цитата Сообщение от Мила Хорошилова Посмотреть сообщение
да. лишнее. оно закомментированно. сканф вообще не нужны при использовании zachita(' '). вопрос в том что написать вместо А[i] [j] = zachita (' A[i] [j]')? потому что пишет ошибку
Текст ошибки выложьте, если не сложно...
Мила Хорошилова
0 / 0 / 0
Регистрация: 05.01.2013
Сообщений: 18
05.01.2013, 20:00  [ТС]     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент #9
Ошибка error C2440: =: невозможно преобразовать 'int' в 'int **'
Если пишу А= zachita ('A')

Добавлено через 2 минуты
// jhgjdf.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
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
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
#include "stdafx.h"
#include "locale.h"
#include "conio.h"
#include "stdlib.h"
#include "time.h"
 
 
 
void text(void);
int input(char *stroka, char c);
int **memory(int M, int N);
void  input_elements(int ***uA, int* uM, int* uN);
void output(int **A, int M, int N);
void task_1(int **A, int M, int N);
void task_2(int **A, int M, int N);
int rnd( int range_min, int range_max );
void end(void);
void save_matrix(int **A, int M, int N);
void read_matrix(int ***uA, int* uM, int* uN);
int zachita(char ch);
 
 
 
int _tmain(int argc, _TCHAR* argv[])
{
 
setlocale(LC_ALL, "Russian");
 
int **A, N, M, m;
bool flag=0;
 
srand(time(NULL));
 
do{
 
system("cls");
 
printf("\nМЕНЮ"
       "\n1 - Ввод данных в программу"
       "\n2 - Решение"
       "\n3 - О программе"
       "\n4 - Выход"
       "\nВведите номер пункта меню: ");
m=zachita('m');
//scanf("%i", &m);
 
switch(m)
{
 
case 1: system("cls");
        input_elements(&A, &M, &N );    
        output(A,M,N);
        end();
        flag=1;
        break;
 
 
case 2: system("cls");
        if (flag==1)
        {       
        output(A,M,N);
        task_1(A,M,N);
        task_2(A,M,N);
        }
        else printf("\nНет данных для решения! Введите данные в пункте 1.");
        end();
        break;
 
 
case 3: system("cls");
        text();
        end();
        break;
 
case 4: break;
 
default: system("cls");
         printf("\nТакого пункта в меню нет! Попробуйте ещё раз "); 
         end();
 
}
 
}while(m!=4);
 
 
return 0;
}
 
void end(void)
{
printf("\nДля перехода в меню нажмите любую клавишу.");
_getch();
}
 
void text(void)
{
printf("\n Автор программы: Хорошилова Людмила. Группа ИКТ-11 \n"
"\n Вариант 12."
"\n*****************************************************************"
"\n*****                Программа: ДВУМЕРНЫЙ МАССИВ            *****"
"\n*****************************************************************"
"\n"
"\nДана целочисленная прямоугольная матрица"
"\n1) Уплотнить заданную матрицу, удаляя из нее строки и столбцы заполненные нулями."
"\n2) Найти номер первой из строк, содержащий хотя бы один положительный элемент.");
 
}
 
int input(char *stroka, char c)
{
    int a;
    do{
    printf("Введите количество %s %c (1<%c<=10): ", stroka, c, c);
    a=zachita('a');
    //scanf("%d", &a);
    }while((a>10)||(a<2));
 
    return a;
}
 
int **memory(int M, int N)
{
 
int **A, i;
 
A=(int **)calloc(M, sizeof(int *));
for(i=0; i<M; i++)
A[i]=(int *)calloc(N, sizeof(int));
 
return A;
}
 
int rnd( int range_min, int range_max )
{
    return (double)rand() / (RAND_MAX + 1) * (range_max - range_min) + range_min;
}
 
void  input_elements(int ***uA, int* uM, int* uN)
{
 
int **A, M, N, m, i, j;
 
do{
 
printf("  ********МЕНЮ******** \n"
       " 1) Заполнение матрицы с клавиатуры\n"
       " 2) Заполнение матрицы случайными числами\n"
       " 3) Заполнение матрицы из файла\n"
       " Ваш выбор : ");
m=zachita('m');
//scanf("%d", &m);
 
switch(m){
 
    case 1: 
 
        M=input("строка",'M');
        N=input("столбцов",'N');
        A=memory(M,N);
                 for(i=0; i<M; i++)
                 for(j=0; j<N; j++)
                 {
                   printf("Введите A[%d][%d]",i+1,j+1);
                   A=zachita('A'); // ??????
                   //scanf("%d", &A[i][j]);
                 }
 
 
            break;
 
    case 2:
        M=input("строка",'M');
        N=input("столбцов",'N');
        A=memory(M,M);
                 for(i=0; i<M; i++)
                 for(j=0; j<N; j++)
                 {
                   
                   A[i][j]=rnd(-10, 10 );
                 }
 
            break;
 
    case 3:
            read_matrix(&A, &M, &N); break;
 
    default: printf("\nТакого действия нет");
        break;
}
 
}while((m!=1)&&(m!=2)&&(m!=3));
 
 
printf("\nСохранить матрицу в файл?"
       "\n 1) Да"
       "\n 2) Нет"
       "\n Ваш выбор: ");
m=zachita('m');
//scanf("%d", &m);
 
switch(m){
 
    case 1: 
            save_matrix(A, M, N);
            break;
 
    case 2:default: break;
}
 
 
*uA=A;
*uM=M;
*uN=N;
 
}
 
void output(int **A, int M, int N)
{
    int i, j;
 
for(i=0; i<M; i++)
{
    for(j=0; j<N; j++) printf("%5d ",A[i][j]);
    printf("\n");
}
 
}
 
 
void task_1(int**A, int M, int N)
{
    int i, j, k;
    bool flag=0;
 
    for (i=0; i<M; i++)
{
    flag=1;
    for (j=0; j<N; j++)
        if (A[i][j]!=0){
            flag=0; break;
                       }
 
if (flag){
   for(k=i; k<(M-1); k++)
       for(j=0; j<N; j++)
           A[k][j]=A[k+1][j];
 
          --i;
          --M;}
}
for (j=0; j<N; j++)
{
    flag=1;
    for (i=0; i<M; i++)
        if (A[i][j]!=0){
            flag=0; break;
                       }
if (flag){
   for(k=j; k<(N-1); k++)
       for(i=0; i<M; i++)
           A[i][k]=A[i][k+1];
   --j;
   --N;}
}
printf("\nПреобразованная матрица:\n");
output(A, M, N);   
 
}
 
 
        void task_2(int**A, int M, int N){
 
    int i, j, num_stroki=0;
    bool flag=0;
for (i=0; (i<M)&&(flag!=1); i++)
for (j=0; j<N; j++)
 
        if (A[i][j]>0)
        {
            num_stroki=i;
            flag=1; break;
        }
 
 
if (flag==1) printf("\n Первый положительный элемент находиться в строке под номером %d",num_stroki+1);
else printf("\n Введенная матрица не содержит положительных элементов.");
}
 
 
void save_matrix(int **A, int M, int N)
{
        FILE *fp; //указатель на поток
 int i,j;
              
              char filename[20];
 
              printf("Введите имя файла:");
              scanf("%s", filename);
 
              fp=NULL;
              fp = fopen(filename, "w");
 
if(fp==NULL)
{
    printf("Ошибка!");
    _getch();
    exit(0);
}
 
 
fprintf(fp,"%d %d\n", M, N);
 
 
for(i=0; i<M; i++)
{
    for(j=0; j<N; j++) fprintf(fp,"%d ",A[i][j]);
    fprintf(fp,"\n");
}
 
 
printf("Запись в файл выполнена. Нажмите любую клавишу.\n");
fclose(fp);
 
 
}
 
 
void read_matrix(int ***uA, int* uM, int* uN)
{
        FILE *fp; //указатель на поток
        int **A, M, N, i,j;
              
              char filename[20];
 
              printf("Введите имя файла:");
              scanf("%s", filename);
 
              fp=NULL;
              fp = fopen(filename, "r");
 
if(fp==NULL)
{
    printf("Ошибка!");
    _getch();
    exit(0);
}
 
 
 
fscanf(fp,"%d%d", &M, &N);
 
A=memory(M,M);
 
 
for(i=0; i<M; i++)
{
    for(j=0; j<N; j++) fscanf(fp,"%d ", &A[i][j]);
//    fprintf(fp,"\n");
}
 
 
printf("Чтение из файла выполнено. Нажмите любую клавишу.\n");
fclose(fp);
 
 
*uA=A;
*uM=M;
*uN=N;
}
 
int zachita(char ch)
{
 
char str[11];//10 цифр-символов и нулевой символ в конце
const int L=10;
char c;
int i, flag=0;
 
 
i=0;
 
//c=_getch();
//printf("\n Код : %d", c);
 
printf(" (  1 <= %c <= 2147483647  ): ", ch);
 
 
while(( (c=_getch())!=13)||(i==0))
{
 
    if (((c==48))&&(i<L)&&(flag!=1)&&(i>0)) //цифра ноль
    {
        printf("%c",c);
        str[i]=c;
        i++;
        str[i]='\0';
 
    }
 
 
    if (((c>=49)&&(c<=55))&&(i<L)&&(flag!=1)) // цифры от 1 до 7
    {
        printf("%c",c);
        str[i]=c;
        i++;
        str[i]='\0';
 
    }
 
    if (((c==56)||(c==57))&&(i<L)&&(flag==0)) // цифры 8 и 9
    {
        printf("%c",c);
        str[i]=c;
        i++;
        str[i]='\0';
 
    }
 
    if ((c==8)&&(str[0]!='\0')) //  bakcspace
    {
      printf("\b \b");
      if (i>0) i--; //если не первая цифра, то уменьшай
      str[i]='\0';
    }
 
    if ( atoi(str)> 214748364) {flag=1;}
    else if ( atoi(str)==214748364) {flag=2;}
    else flag=0;
        
 
 
    //printf("\n Код : %d", c);
 
}
 
return atoi(str);
}


вот вся прога. вдруг поможет_))
Андрей\
3 / 3 / 0
Регистрация: 13.12.2011
Сообщений: 22
05.01.2013, 20:09     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент #10
Так все просто: A[i][j] нужно писать вместо A...
А так по коду: непонятно зачем Вы 'A[i][j]' в функцию кидаете...
И еще...что-то код очень знакомый...ощущение дежа-вю...не знаете где я мог его видеть?
Мила Хорошилова
0 / 0 / 0
Регистрация: 05.01.2013
Сообщений: 18
05.01.2013, 20:15  [ТС]     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент #11
Ошибка error C2015: слишком много знаков в константе
вылазит когда так пишу. а про код не знаю.. если вы только к политеху кировскому отношение имеете какое нибудь, то все возможно
Андрей\
3 / 3 / 0
Регистрация: 13.12.2011
Сообщений: 22
05.01.2013, 20:20     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент #12
на какую строчку ругается?
Насчет Политеха...Весьма вероятно, что Вы все это писали по образцу моей зачетной программы или программы моей одногруппницы...Мир тесен...
Мила Хорошилова
0 / 0 / 0
Регистрация: 05.01.2013
Сообщений: 18
05.01.2013, 20:22  [ТС]     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент #13
все. сделала. только 0 не выводит( все не слава богу

Добавлено через 1 минуту
кононова виктория юрьевна дала нашей группе этот образец)
Андрей\
3 / 3 / 0
Регистрация: 13.12.2011
Сообщений: 22
05.01.2013, 20:26     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент #14
Цитата Сообщение от Мила Хорошилова Посмотреть сообщение
все. сделала. только 0 не выводит( все не слава богу

Что значит не выводит?
Повезло еще, что Кононова, а не НТВ, я у нее зачет в марте получил...

Вот
C
1
if (((c==48))&&(i<L)&&(flag!=1)&&(i>0))
первый ноль блокируется (i>0)
Мила Хорошилова
0 / 0 / 0
Регистрация: 05.01.2013
Сообщений: 18
05.01.2013, 20:31  [ТС]     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент #15
про кононову абсолютно верно. а вот про код. я не могу ноль нажать и минус
Андрей\
3 / 3 / 0
Регистрация: 13.12.2011
Сообщений: 22
05.01.2013, 20:38     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент #16
Цитата Сообщение от Мила Хорошилова Посмотреть сообщение
про кононову абсолютно верно. а вот про код. я не могу ноль нажать и минус
а минус вообще не прописан. Совет: поставьте мою защиту, просто функцию поменяйте, там все работает
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
05.01.2013, 21:26     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент
Еще ссылки по теме:

C++ Объсните эксперты как реализовать последнее условие, Уплотнить заданную матрицу, удаляя из нее строки и столбцы, заполненные нулями
Уплотнить заданную матрицу, удаляя из нее строки и столбцы, заполненные нулями C++
C++ Уплотнить заданную матрицу, удаляя из нее строки и столбцы, заполненные нулями

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

Или воспользуйтесь поиском по форуму:
Мила Хорошилова
0 / 0 / 0
Регистрация: 05.01.2013
Сообщений: 18
05.01.2013, 21:26  [ТС]     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент #17
сейчас попробую

Добавлено через 43 минуты
спасибо огромное)) я все сделала))
Yandex
Объявления
05.01.2013, 21:26     Уплотнить матрицу,удаляя из нее строки и столбцы, заполненные нулями.Найти номер первой из строк,содержащих хотя бы один положительный элемент
Ответ Создать тему
Опции темы

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