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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 26, средняя оценка - 5.00
Kronoz
0 / 0 / 0
Регистрация: 13.12.2010
Сообщений: 12
#1

В каждой строке матрицы заменить на 0 все элементы до первого отрицательного элемента - C++

13.12.2010, 00:23. Просмотров 3280. Ответов 10
Метки нет (Все метки)

Доброго времени суток! Помогите, пожалуйста, с задачей:
Среда CodeGear RAD Studio 2009.
Разработать алгоритм и отладить программу, используя динамический массив. Дана матрица А(m, n). В каждой строке матрицы заменить на 0 все элементы до первого отрицательного элемента.
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
#include <clocale>
#include <iostream>
#include <conio.h>
#pragma hdrstop
using namespace std;
//---------------------------------------------------------------------------
int main()
{
// Установка русской кодировки:
    setlocale(LC_ALL, "Russian");
// Ввод размерности массива:
    unsigned short m = 128, n = 128;
    wcout << L"Введите число строк M и число столбцов N:\n";
    cin >> m >> n;
// Объявление 2х-мерного динамического массива:
    short ** A = new short * [m]; // Выделение памяти под указатели на строки.
    for (short i = 0; i < m; i++) // Память под строки.
    A[i] = new short [n];
// Ввод элементов массива:
    wcout << L"Введите элементы массива:\n";
    for (short i = 0; i < m; i++)
        for (short j = 0; j < n; j++)
            cin >> A[i][j];
 
// Почему-то не работает:
/*
    for (short i = 0; i < m; i++) {
        for (short j = 0; j < n; j++) {
            if (A[i][j] < 0) {
                for (short k = 0; k < j; k++) {
                    A[i][k] = 0;
                }
                j = 0;
                i++;
            }
        }
    }
*/
 
// А здесь ничего не происходит:
/*
short i = 0, j = 0;
while (i < m) {
    while (j < n) {
        if (A[i][j] < 0) {
            short k = 0;
            while (k < j) {
                A[i][k] = 0;
                k++;
            }
            j = 0;
            i++;
        }
        j++;
    }
i++;
}
*/
// В чём же дело?
 
// Вывод массива:
    for (short i = 0; i < m; i++) {
        for (short j = 0; j < n; j++) {
            cout << A[i][j] << ' ';
        }
        cout << '\n';
    }
    getch();
    return 0;
}
0
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
13.12.2010, 00:23
Здравствуйте! Я подобрал для вас темы с ответами на вопрос В каждой строке матрицы заменить на 0 все элементы до первого отрицательного элемента (C++):

В каждой строке матрицы вычислить произведение частей стоящих до первого отрицательного элемента - C++
Задана целая матрица T. Вычислить произведение частей, стоящих до первого отрицательного, в каждой строке матрицы. Считать, что в каждой...

Заменить все элементы главной диагонали заданной матрицы значением первого элемента - C++
Дан двумерный статический массив действительных чисел размером 6х5. Заменить все элементы главной диагонали первым элементом.

Найти индекс первого отрицательного элемента и заменить на него элементы массива по условию - C++
Программа должна осуществить ввод массива из 50 вещественных элементов (либо по выбору пользователя задать их через функцию rand() модуля...

Для каждой строки матрицы найти номер первого отрицательного элемента, и записать данные в новый массив - C++
Дан массив размером n*n, элементы которого целые числа. Для каждой строки найти номер первого отрицательного элемента и записать данные...

Для каждой строки матрицы найти индекс первого отрицательного элемента и записать данные в новый массив - C++
Для каждой строки найти номер первого отрицательного элемента и записать данные в новый массив: Где комментарий, я не могу понять, что...

Из существующей матрицы n*m записать в новую матрицу все элементы исходной матрицы, кроме максимального и минимального элемента из каждой строки - C++
Здравствуйте! У меня такая задача: мне надо из существующей матрицы n*m запсать в новую матрицу все элементы исходной матрицы, кроме...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Crudelis
Шаровик затейник
674 / 416 / 13
Регистрация: 06.05.2010
Сообщений: 1,109
13.12.2010, 00:26 #2
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
C++
1
2
3
4
5
6
if (A[i][j] >= 0) {
                                for (short k = 0; k < j; k++) {
                                        A[i][k] = 0;
                                }
                                j = 0;
                                i++;
так попробуйте
0
Kronoz
0 / 0 / 0
Регистрация: 13.12.2010
Сообщений: 12
13.12.2010, 00:31  [ТС] #3
Немного не понял, зачем. Нужно же до первого отрицательного, а не неотрицательного.
0
Crudelis
Шаровик затейник
674 / 416 / 13
Регистрация: 06.05.2010
Сообщений: 1,109
13.12.2010, 00:36 #4
Цитата Сообщение от Kronoz Посмотреть сообщение
В каждой строке матрицы заменить на 0 все элементы до первого отрицательного элемента
какая делается проверка:
если элемент массива больше нуля(поясню не отрицательный) либо равен нулю(поясню не отрицательный) то мы заменяем элементы на ноль, что и нужно в задаче сделать

Добавлено через 2 минуты
но я бы сделал по другому:
C++
1
2
3
4
if (A[i][j] >= 0)
    A[i][j]=0;
if(A[i][j]<0)
j=n-1;//т.е. переход на след. значение i другая строка
1
Kronoz
0 / 0 / 0
Регистрация: 13.12.2010
Сообщений: 12
13.12.2010, 00:40  [ТС] #5
В Вашем случае строка обнулится в любом случае, даже если все положительные, но нам нужно заменить до 1го отрицательного (если есть).
0
MILAN
885 / 779 / 86
Регистрация: 21.02.2009
Сообщений: 1,722
13.12.2010, 00:51 #6
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
#include <clocale>
#include <iostream>
#include <conio.h>
#pragma hdrstop
using namespace std;
//---------------------------------------------------------------------------
int main()
{
// Установка русской кодировки:
        setlocale(LC_ALL, "Russian");
// Ввод размерности массива:
        unsigned short m = 128, n = 128,cnt_i,cnt_j,count=0;
        wcout << L"Введите число строк M и число столбцов N:\n";
        cin >> m >> n;
// Объявление 2х-мерного динамического массива:
        short ** A = new short * [m]; // Выделение памяти под указатели на строки.
        for (short i = 0; i < m; i++) // Память под строки.
        A[i] = new short [n];
// Ввод элементов массива:
        wcout << L"Введите элементы массива:\n";
        for (short i = 0; i < m; i++)
                for (short j = 0; j < n; j++)
                        cin >> A[i][j];
 
// Почему-то не работает:
        for (short i = 0; i < m; i++) 
        {
                for (short j = 0; j < n; j++) 
                {
                        if (A[i][j] < 0 && !count) 
                        {
                            cnt_i=i;
                            cnt_j=j;
                             count++;
                              break;
                        }
                    if(count)
                    {
                        break;
                    }
                        
                }
        }
// Вывод массива:
        count=0;
        for (short i = 0; i < m; i++) 
        {
                for (short j = 0; j < n; j++)
                {
                    if(i==cnt_i && j==cnt_j)
                    {
                        count++;
                    }
                     if(!count)
                     {
                        A[i][j]=0;
                     }
                  cout << A[i][j] << ' ';
                }
        cout << '\n';
          }
    getch();
        return 0;
}
0
Kronoz
0 / 0 / 0
Регистрация: 13.12.2010
Сообщений: 12
13.12.2010, 00:59  [ТС] #7
Цитата Сообщение от MILAN Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
        for (short i = 0; i < m; i++) 
        {
                for (short j = 0; j < n; j++) 
                {
                        if (A[i][j] < 0 && !count) 
                        {
                            cnt_i=i;
                            cnt_j=j;
                             count++;
                              break;
                        }
                    if(count)
                    {
                        break;
                    }
                        
                }
        }
}
В этом случае массив будет обнуляться только до 1го отрицательного элемента; если в массиве их несколько на разных строках, то задача будет решена неверно.
0
MILAN
885 / 779 / 86
Регистрация: 21.02.2009
Сообщений: 1,722
13.12.2010, 01:03 #8
Kronoz, вы програму хоть запускали? Покажыте скрин результата!!!!!
0
Миниатюры
В каждой строке матрицы заменить на 0 все элементы до первого отрицательного элемента  
Kronoz
0 / 0 / 0
Регистрация: 13.12.2010
Сообщений: 12
13.12.2010, 01:13  [ТС] #9
Цитата Сообщение от MILAN Посмотреть сообщение
Kronoz, вы програму хоть запускали? Покажыте скрин результата!!!!!
Вот скрин с Вашим вариантом:
http://s1.ipicture.ru/Gallery/Viewfull/2579203.html

А вот какую ошибку выдаёт с моим 1м вариантом:
http://s1.ipicture.ru/Gallery/Viewfull/2579210.html
0
MILAN
885 / 779 / 86
Регистрация: 21.02.2009
Сообщений: 1,722
13.12.2010, 01:16 #10
Блин, задание не так понял!!!!
0
Kronoz
0 / 0 / 0
Регистрация: 13.12.2010
Сообщений: 12
13.12.2010, 01:41  [ТС] #11
Цитата Сообщение от Crudelis Посмотреть сообщение
какая делается проверка:
если элемент массива больше нуля(поясню не отрицательный) либо равен нулю(поясню не отрицательный) то мы заменяем элементы на ноль, что и нужно в задаче сделать

Добавлено через 2 минуты
но я бы сделал по другому:
C++
1
2
3
4
if (A[i][j] >= 0)
    A[i][j]=0;
if(A[i][j]<0)
j=n-1;//т.е. переход на след. значение i другая строка
Сначала Вас недопонял. Так заработало, большое спасибо.
Вот конечный результат:
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
// Разработать алгоритм и отладить программу, используя динамический массив.
// 6.   Дана матрица А(m, n). В каждой строке матрицы заменить
//      на 0 все элементы до первого отрицательного элемента.
//---------------------------------------------------------------------------
#include <clocale>
#include <iostream>
#include <conio.h>
#pragma hdrstop
using namespace std;
//---------------------------------------------------------------------------
int main()
{
// Установка русской кодировки:
    setlocale(LC_ALL, "Russian");
// Ввод размерности массива:
    unsigned short m = 128, n = 128;
    wcout << L"Введите число строк M и число столбцов N:\n";
    cin >> m >> n;
// Объявление 2х-мерного динамического массива:
    short ** A = new short * [m]; // Выделение памяти под указатели на строки.
    for (short i = 0; i < m; i++) // Память под строки.
    A[i] = new short [n];
// Ввод элементов массива:
    wcout << L"Введите элементы массива:\n";
    for (short i = 0; i < m; i++)
        for (short j = 0; j < n; j++)
            cin >> A[i][j];
// Обнуление:
    for (short i = 0; i < m; i++) {
        for (short j = 0; j < n; j++) {
                if (A[i][j] >= 0) A[i][j]=0;
                else j=n-1;
            }
        }
// Вывод массива:
    cout << '\n';
    for (short i = 0; i < m; i++) {
        for (short j = 0; j < n; j++) {
            cout << A[i][j] << ' ';
        }
        cout << '\n';
    }
    getch();
    return 0;
}
//---------------------------------------------------------------------------
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
13.12.2010, 01:41
Привет! Вот еще темы с ответами:

Увеличить все элементы матрицы на значение первого элемента найденной строки - C++
Найти в матрице первую строку, все элементы которой имеют отрицательное значение. Увеличить все элементы матрицы на значение первого...

Для каждой строки найти номер первого отрицательного элемента и записать данные в новый массив - C++
Решите пожалуйста. Завтра надо сдать. Для каждой строки найти номер первого отрицательного элемента и записать данные в новый массив.

В каждой строке матрицы Z(5,6) сдвинуть все элементы вправо на один разряд - C++
Люди добрые, помогите. В каждой строке матрицы Z(5,6) сдвинуть все элементы вправо на один разряд (циклически). Если при этом в последнем...

В квадратной матрице найти номер первого отрицательного элемента в строке и составить из них массив. - C++
Помогите плз. Никак соображу как сделать лабу. Дан массив размером nxn, элементы которого целые числа. Для каждой строки найти номер...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
13.12.2010, 01:41
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru