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

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

Войти
Регистрация
Восстановить пароль
 
ra4ok
0 / 0 / 0
Регистрация: 12.10.2011
Сообщений: 37
#1

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

03.10.2012, 21:20. Просмотров 714. Ответов 8
Метки нет (Все метки)

Добрый вечер всем.
Дана целочисленная прямоуг. матрица. Определить номер первого из столбцов, содержащих хотя бы 1 нулевой эл-т.
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
#include <iostream>
#include <iomanip>
using namespace std;
 
int main()
{
    const int n = 5;
    int i,j,arr[n][n];
    cout<<"Massiv= "<<endl;
    for (i=0;i<n;i++)
    {
        for (j=0;j<n;j++)
        {
            arr[i][j]=rand()%20-10;
            cout<<setw(5)<<arr[i][j];
        }
        cout << endl;
    }
int stolbec;
for(i=0;i<n;i++)
{
    for(j=0;j<n;j++)
    {
        if(arr[i][j]==0)
            stolbec=j;
        
    }
}
cout<<"Nomer pervogo stolbca soderjawego 0: "<<stolbec<<endl;
    return 0;
}
Программа работает правильно, если есть в 0ом столбце 0, если же дальше она не работает.В чем проблема?подскажите плиз.
И если не сложно, помогите с заданием: Характеристикой строки целочисленной матрицы назовем сумму ее отрицательных четных эл-ов. Переставляя строки заданной матрицы, расположить их в соответствии с убыванием характеристик.
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.10.2012, 21:20
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Определить номер первого из столбцов, содержащих хотя бы 1 нулевой элемент (C++):

Определить: номер первого из столбцов, содержащих хотя бы один нулевой элемент - C++
Составить функцию Run которая позволит выполнить следующие действия с двухмерными массивами (если задачу решить нельзя, то сообщит об...

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

Определить номер первого из столбцов, содержащих хотя бы один нулевой элемент - C++
Помогите решить задачу 15. Дана целочисленная прямоугольная матрица: а) определить номер первого из столбцов, содержащих хотя...

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

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

Определить номер первого из столбцов матрицы, содержащих хотя бы один нулевой элемент - C++
Задача с двумерным массивом на C (не C++). Дана целочисленная прямоугольная матрица. Определить номер первого из столбцов, содержащих...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
valeriikozlov
Эксперт C++
4670 / 2496 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
03.10.2012, 21:26 #2
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
#include <iostream>
#include <iomanip>
using namespace std;
 
int main()
{
    const int n = 5;
    int i,j,arr[n][n];
    cout<<"Massiv= "<<endl;
    for (i=0;i<n;i++)
    {
        for (j=0;j<n;j++)
        {
            arr[i][j]=rand()%20-10;
            cout<<setw(5)<<arr[i][j];
        }
        cout << endl;
    }
int stolbec;
for(i=0;i<n;i++)
{
    for(j=0;j<n;j++)
    {
        if(arr[j][i]==0)
        {
            stolbec=i;
            cout<<"Nomer pervogo stolbca soderjawego 0: "<<stolbec<<endl;
            return 0;
 
        }
        
    }
}
cout<<"Takih stolbcov net"<<endl;
    return 0;
}
1
ra4ok
0 / 0 / 0
Регистрация: 12.10.2011
Сообщений: 37
03.10.2012, 21:36  [ТС] #3
Цитата Сообщение от valeriikozlov Посмотреть сообщение
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
#include <iostream>
#include <iomanip>
using namespace std;
 
int main()
{
    const int n = 5;
    int i,j,arr[n][n];
    cout<<"Massiv= "<<endl;
    for (i=0;i<n;i++)
    {
        for (j=0;j<n;j++)
        {
            arr[i][j]=rand()%20-10;
            cout<<setw(5)<<arr[i][j];
        }
        cout << endl;
    }
int stolbec;
for(i=0;i<n;i++)
{
    for(j=0;j<n;j++)
    {
        if(arr[j][i]==0)
        {
            stolbec=i;
            cout<<"Nomer pervogo stolbca soderjawego 0: "<<stolbec<<endl;
            return 0;
 
        }
        
    }
}
cout<<"Takih stolbcov net"<<endl;
    return 0;
}
а со второй частью программы можете помочь?
и еще вопрос, почему не используется Else? Вместо него return 0?
0
Thinker
Эксперт C++
4226 / 2200 / 150
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
03.10.2012, 21:47 #4
можно так:
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
#include <iostream>
#include <iomanip>
using namespace std;
 
const int N = 5;
 
int Check(int a[][N], int n, int k)
{
   int i;
   for(i = -1; ++i < n && a[i][k]; )
      ;
   return i < n;
}
 
int main()
{
    int i, j, a[N][N];
    for (i = 0; i < N; i++)
    {
        for (j = 0; j < N; j++)
            cout << setw(5) << (a[i][j] = rand()%20-10) << " ";
        cout << endl;
    }
    for(i = -1; ++i < N && !Check(a, N, i); )
       ;
    cout << (i < N ? i : -1);
    return 0;
}
1
ra4ok
0 / 0 / 0
Регистрация: 12.10.2011
Сообщений: 37
03.10.2012, 21:49  [ТС] #5
Цитата Сообщение от Thinker Посмотреть сообщение
можно так:
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
#include <iostream>
#include <iomanip>
using namespace std;
 
const int N = 5;
 
int Check(int a[][N], int n, int k)
{
   int i;
   for(i = -1; ++i < n && a[i][k]; )
      ;
   return i < n;
}
 
int main()
{
    int i, j, a[N][N];
    for (i = 0; i < N; i++)
    {
        for (j = 0; j < N; j++)
            cout << setw(5) << (a[i][j] = rand()%20-10) << " ";
        cout << endl;
    }
    for(i = -1; ++i < N && !Check(a, N, i); )
       ;
    cout << (i < N ? i : -1);
    return 0;
}
такое мне практически не понятно...
0
Ev[G]eN
Эксперт С++
5097 / 1535 / 381
Регистрация: 23.01.2011
Сообщений: 3,148
03.10.2012, 22:13 #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
#include <iostream>
#include <iomanip>
#include <cstdlib>
#include <ctime>
 
int main()
{
    srand(time(0));
    
    const int matrixSize = 5;
    int Matrix[matrixSize][matrixSize], collNumber = 0, Check = 0;
    
    std::cout << "Matrix: " << std::endl;
    for(int i = 0; i < matrixSize; i++)
    {
            for(int j = 0; j < matrixSize; j++)
                    std::cout << std::setw(4) << (Matrix[i][j] = rand() % 5);
            std::cout << std::endl;
    }
    
    std::cout << "First coll's number with zero element: ";
    for(int j = 0; j < matrixSize; j++)
            for(int i = 0; i < matrixSize; i++)
            {
                    if(!Check)
                              if(!Matrix[i][j])
                              {
                                               Check = 1;
                                               collNumber = j;
                              }
            }
    std::cout << collNumber + 1 << std::endl;
    
    system("pause");
    return 0;
}
1
ra4ok
0 / 0 / 0
Регистрация: 12.10.2011
Сообщений: 37
03.10.2012, 22:19  [ТС] #7
Цитата Сообщение от Ev[G]eN Посмотреть сообщение
как вариант
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
#include <iostream>
#include <iomanip>
#include <cstdlib>
#include <ctime>
 
int main()
{
    srand(time(0));
    
    const int matrixSize = 5;
    int Matrix[matrixSize][matrixSize], collNumber = 0, Check = 0;
    
    std::cout << "Matrix: " << std::endl;
    for(int i = 0; i < matrixSize; i++)
    {
            for(int j = 0; j < matrixSize; j++)
                    std::cout << std::setw(4) << (Matrix[i][j] = rand() % 5);
            std::cout << std::endl;
    }
    
    std::cout << "First coll's number with zero element: ";
    for(int j = 0; j < matrixSize; j++)
            for(int i = 0; i < matrixSize; i++)
            {
                    if(!Check)
                              if(!Matrix[i][j])
                              {
                                               Check = 1;
                                               collNumber = j;
                              }
            }
    std::cout << collNumber + 1 << std::endl;
    
    system("pause");
    return 0;
}
Вообще шикарно, все понятно Можете со второй частью помочь?
0
valeriikozlov
Эксперт C++
4670 / 2496 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
04.10.2012, 00:03 #8
Цитата Сообщение от ra4ok Посмотреть сообщение
Вообще шикарно,
ну тогда берем за основу этот код:
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
#include <iostream>
#include <iomanip>
#include <cstdlib>
#include <ctime>
#include <algorithm> 
int main()
{
    srand(time(0));
    
    const int matrixSize = 5;
    int Matrix[matrixSize][matrixSize], collNumber = 0, Check = 0, A[matrixSize]={0}, i_min;
    
    std::cout << "Matrix: " << std::endl;
    for(int i = 0; i < matrixSize; i++)
    {
            for(int j = 0; j < matrixSize; j++)
            {
                    std::cout << std::setw(4) << (Matrix[i][j] = rand() % 20-10);
                    if(Matrix[i][j]<0 && Matrix[i][j]%2==0)
                        A[i]+=Matrix[i][j];
            }
            std::cout << std::endl;
    }
    
    std::cout << "First coll's number with zero element: ";
    for(int j = 0; j < matrixSize; j++)
            for(int i = 0; i < matrixSize; i++)
            {
                    if(!Check)
                              if(!Matrix[i][j])
                              {
                                               Check = 1;
                                               collNumber = j;
                              }
            }
    std::cout << collNumber + 1 << std::endl;
    for(int i=0; i<matrixSize-1; i++)
    {
        i_min=i;
        for(int j=i+1; j<matrixSize; j++)
            if(A[i_min]<A[j])
                i_min=j;
        std::swap(A[i_min], A[i]);
        for(int j=0; j<matrixSize; j++)
            std::swap(Matrix[i_min][j], Matrix[i][j]);
    }
   std::cout << "New matrix: " << std::endl;
    for(int i = 0; i < matrixSize; i++)
    {
            for(int j = 0; j < matrixSize; j++)
            {
                    std::cout << std::setw(4) << Matrix[i][j]<< " ";
            }
            std::cout << std::endl;
    }   
    
    system("pause");
    return 0;
}
1
ra4ok
0 / 0 / 0
Регистрация: 12.10.2011
Сообщений: 37
04.10.2012, 01:06  [ТС] #9
Цитата Сообщение от valeriikozlov Посмотреть сообщение
ну тогда берем за основу этот код:
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
#include <iostream>
#include <iomanip>
#include <cstdlib>
#include <ctime>
#include <algorithm> 
int main()
{
    srand(time(0));
    
    const int matrixSize = 5;
    int Matrix[matrixSize][matrixSize], collNumber = 0, Check = 0, A[matrixSize]={0}, i_min;
    
    std::cout << "Matrix: " << std::endl;
    for(int i = 0; i < matrixSize; i++)
    {
            for(int j = 0; j < matrixSize; j++)
            {
                    std::cout << std::setw(4) << (Matrix[i][j] = rand() % 20-10);
                    if(Matrix[i][j]<0 && Matrix[i][j]%2==0)
                        A[i]+=Matrix[i][j];
            }
            std::cout << std::endl;
    }
    
    std::cout << "First coll's number with zero element: ";
    for(int j = 0; j < matrixSize; j++)
            for(int i = 0; i < matrixSize; i++)
            {
                    if(!Check)
                              if(!Matrix[i][j])
                              {
                                               Check = 1;
                                               collNumber = j;
                              }
            }
    std::cout << collNumber + 1 << std::endl;
    for(int i=0; i<matrixSize-1; i++)
    {
        i_min=i;
        for(int j=i+1; j<matrixSize; j++)
            if(A[i_min]<A[j])
                i_min=j;
        std::swap(A[i_min], A[i]);
        for(int j=0; j<matrixSize; j++)
            std::swap(Matrix[i_min][j], Matrix[i][j]);
    }
   std::cout << "New matrix: " << std::endl;
    for(int i = 0; i < matrixSize; i++)
    {
            for(int j = 0; j < matrixSize; j++)
            {
                    std::cout << std::setw(4) << Matrix[i][j]<< " ";
            }
            std::cout << std::endl;
    }   
    
    system("pause");
    return 0;
}
спасибо огромное
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
04.10.2012, 01:06
Привет! Вот еще темы с ответами:

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

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

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

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


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

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

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