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

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

Войти
Регистрация
Восстановить пароль
 
Kemsit
4 / 4 / 1
Регистрация: 07.06.2009
Сообщений: 62
#1

Из матрицы вырезать те элементы, которые помечены белым - C++

20.12.2009, 20:26. Просмотров 476. Ответов 7
Метки нет (Все метки)

Задали лабу, 2/3 сделал, а вот с третьем заданием вышла заминка... Помогите! Дана матрица, из неё нужно вырезать те элементы, которые помечены белым. И оставить те, что попадают в чёрную область.
Из матрицы вырезать те элементы, которые помечены белым
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
using namespace std;
int main()
{
    setlocale(LC_ALL, "Russian");
    cout<<"Введите количество строк массива"<<endl;
    cin>>x;
    cout<<"Введите количество столбцов массива"<<endl;
    cin>>y;
    for (int i=0; i<x; i++)
    {
        for (int j=0; j<y; j++)
        {
            cout<<"Введите элемент ["<<i<<','<<j<<"] -> ";
            cin>>mass[i][j];
        }
    }
system ("pause");
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.12.2009, 20:26
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Из матрицы вырезать те элементы, которые помечены белым (C++):

дописать ( Из массива А удалить все элементы, которые встречаются в В ровно 2 раза. Из В переписать в С те элементы, которые совпадают с оставшимися) - C++
нужно чтоб на экран еще выводило перед новым массивом А, числа,которые повторяются в массиве В 2 раза. и перед С тоже чтоб выводило на...

В массив С перенести те элементы А, которые меньше min(В), и те элементы B, которые больше max(A) - C++
Ввести массивы А и В. В массив С перенести те элементы массива А , которые меньше минимального элемента массива В , и те элементы массива В...

Как получить элементы матрицы, которые находятся ниже побочной диагонали? - C++
работа с матрицами. как описать элементы, которые находятся ниже побочной диагонали? если можно, то дайте пример пожалуйста

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

Поменять местами элементы квадратной матрицы, которые симметричны побочной диагонали - C++
Поменять местами элементы квадратной матрицы, которые симметричны побочной диагонали. Составить блок-схему и написать код. Помогите, прошу!

Переписать первые элементы каждой строки матрицы D(3,3), которые больше 10, в массив В - C++
Переписать первые элементы каждой строки матрицы D(3,3), которые больше 10, в массив В. Выполнить с использованием указателей и без. ...

7
valeriikozlov
Эксперт С++
4670 / 2496 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
20.12.2009, 20:51 #2
Что значит вырезать? Заменить на нули? Не выводить на экран?
0
Kemsit
4 / 4 / 1
Регистрация: 07.06.2009
Сообщений: 62
20.12.2009, 20:52  [ТС] #3
Цитата Сообщение от valeriikozlov Посмотреть сообщение
Что значит вырезать? Заменить на нули? Не выводить на экран?
Не выводить на экран. Вывести только те элементы, которые попадают в чёрную область.
0
valeriikozlov
Эксперт С++
4670 / 2496 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
20.12.2009, 20:55 #4
В таком же виде как на рисунке?
0
Kemsit
4 / 4 / 1
Регистрация: 07.06.2009
Сообщений: 62
20.12.2009, 20:58  [ТС] #5
Цитата Сообщение от valeriikozlov Посмотреть сообщение
В таком же виде как на рисунке?
Желательно да. Но можно и каскадом. К примеру.
1
11
111
1111
1111
1111
111
11
1
Показал криво, но как то так))
0
valeriikozlov
Эксперт С++
4670 / 2496 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
20.12.2009, 21:10 #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
#include <iostream.h>
#include <windows.h>
 
int main ()
{
    int **mas, n, m, i,j, temp=1;
    bool fl=true;
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    cout<<"Ââåäèòå êîëè÷åñòâî ñòîëáöîâ Г¬Г*òðèöû: "<< endl;
    cin>>m;
    n=m*2-1;
    mas=new int*[n]; 
    for(i=0; i<n; i++)
       mas[i]=new int[m];
    cout<<"Ââåäèòå ýëåìåГ*ГІГ» Г¬Г*òðèöû: "<< endl;
    for(i=0; i<n; i++)
       for(j=0; j<m; j++)
       {
          cout<<"["<<i<<"]["<<j<<"]= ";
          cin>>mas[i][j];
       }
        cout<<"èñõîäГ*Г*Гї Г¬Г*òðèöГ*"<<endl;
    for(i=0; i<n; i++)
        {
       for(j=0; j<m; j++)
       {
           cout.width(4);
          cout<<mas[i][j];
       }
          cout<<endl;
        }
    cout<<"òðåóãîëüГ*ûé ГўГЁГ¤"<<endl;
    for(i=0; i<n; i++)
    {
       for(j=0; j<m; j++)
       {
           cout.width(4);
           if(j<m-temp)
               cout<<" ";
           else
          cout<<mas[i][j];
       }
       if(temp==m)
           fl=false;
       if(fl)
           temp++;
       if(!fl)
           temp--;
          cout<<endl;
        }      
        
        cout<<endl; 
    return 0; 
}
Только одно дополнение. Мы вводим только количество столбцов. Кол-во строк вычисляем 2*n-1, что бы матрица была подходящего вида для такого вывода.
1
Kemsit
4 / 4 / 1
Регистрация: 07.06.2009
Сообщений: 62
20.12.2009, 22:05  [ТС] #7
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
    #include <iostream>
using namespace std;
int main()
{
    setlocale(LC_ALL, "Russian");
    int x, y, mass[256][256], count=0, temp=0, dop_mass[256], dop_mass1[256][256], dop_mass2[256][256], y1;
    cout<<"Лабораторная работа №3, Вариант №8"<<endl;
    cout<<"Работу выполнил студент ДИН-21, Иванов Сергей"<<endl;
    cout<<"Введите количество строк массива"<<endl;
    cin>>x;
    cout<<"Введите количество столбцов массива"<<endl;
    cin>>y;
    for (int i=0; i<x; i++)
    {
        for (int j=0; j<y; j++)
        {
            cout<<"Введите элемент ["<<i<<','<<j<<"] -> ";
            cin>>mass[i][j];
        }
    }
    for (int i=0; i<x; i++)
    {
        for (int j=0; j<y; j++)
        {
            cout<<mass[i][j]<<"        ";
            if (j==y-1)
            {
                cout<<endl;
            }
        }
    }
temp=1;
    int m=0;
    cout<<"Матрица, с удалёнными по правилу элементами"<<endl;
    y1=y-(y/3);
    for (int i=0; i<x; i++)
    {
        for (int j=y1; j<y; j++)
        {
            dop_mass2[i][m]=mass[i][j];
            m++;
        }
        m=0;
    }
    m=y-y1;
    bool fl = true;
    for(int i=0; i<x; i++)
    {
       for(int j=0; j<m; j++)
           {
                   cout.width(4);
                   if(j<m-temp)
                   {
                           cout<<" ";
                   }
                   else
                   {
                           cout<<dop_mass2[i][j];
                   }
           }
           if(temp==m)
           {
                   fl=false;
           }
           if(fl)
           {
                   temp++;
           }
           if(!fl)
           {
                   temp--;
           }
          cout<<endl;
        }      
    system ("pause");
    return 0;
}
Чёт не совсем получается, хотя уже что-то. Посмотрите пжл!
0
valeriikozlov
Эксперт С++
4670 / 2496 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
20.12.2009, 22:57 #8
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
Kemsit, Вы в этом коде сами задаете кол-во строк. Я же когда код писал, сделал приписочку внизу. Мы задаем только кол-во столбцов, кол-во строк программа считает сама (2*n-1, где n - кол-во столбцов), что бы вывести такой треугольник.
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
#include <iostream>
 
using namespace std;
int main()
{
        setlocale(LC_ALL, "Russian");
        int m, n, i, j, temp=1, **mas;
        bool fl=true;
        cout<<"Лабораторная работа №3, Вариант №8"<<endl;
        cout<<"Работу выполнил студент ДИН-21, Иванов Сергей"<<endl;
   cout<<"Введите количество столбцов матрицы: "<< endl;
    cin>>m;
        n=m*2-1;
    mas=new int*[n]; 
    for(i=0; i<n; i++)
       mas[i]=new int[m];
    cout<<"Введите элементы матрицы: "<< endl;
    for(i=0; i<n; i++)
       for(j=0; j<m; j++)
       {
          cout<<"["<<i<<"]["<<j<<"]= ";
          cin>>mas[i][j];
       }
        cout<<"исходная матрица"<<endl;
    for(i=0; i<n; i++)
        {
       for(j=0; j<m; j++)
           {
                   cout.width(4);
          cout<<mas[i][j];
           }
          cout<<endl;
        }
        cout<<"треугольный вид"<<endl;
    for(i=0; i<n; i++)
    {
       for(j=0; j<m; j++)
           {
                   cout.width(4);
                   if(j<m-temp)
                           cout<<" ";
                   else
          cout<<mas[i][j];
           }
           if(temp==m)
                   fl=false;
           if(fl)
                   temp++;
           if(!fl)
                   temp--;
          cout<<endl;
        }      
        
        cout<<endl; 
    return 0; 
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
20.12.2009, 22:57
Привет! Вот еще темы с ответами:

Переписать первые элементы каждой строки матрицы D(3,3), которые больше 10, в массив В. - C++
Пожалуйста помогите написать прогу на C Переписать первые элементы каждой строки матрицы D(3,3), которые больше 10, в массив В.

Заменить нулями элементы матрицы, которые больше, чем среднее арифметическое - C++
Не получается нормально построить функцию. #include &lt;iostream&gt; using namespace std; void zamena(int a) { int s = 0; {for(int...

Найти сумму элементов матрицы в тех столбцах, которые имеют отрицательные элементы - C++
Добрый день, помогите, пожалуйста, с функцией: int summa (int **ar,int n) {int k,sum,i,j; for (i=0;i&lt;=n; i++) { k=1; sum=0; for...

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


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

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

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