Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
NewBayan
0 / 0 / 0
Регистрация: 16.02.2015
Сообщений: 1
#1

Помогите найти ошибку в программе

16.02.2015, 05:39. Просмотров 262. Ответов 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
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
#include <stdio.h>
#include <conio.h>
void FormMassive(int A[4][4],int B[4][4],int IA,int IB,int i,int j)
{
int C[4][4];
if(IA>IB)
{
    for(int i=1;i<=4;i++);
    for(int j=1;j<=4;j++);
    {
        if(i==1)C[i-1][j-1]=A[IA-1][j-1];
        else if(i==IA)C[i-1][j-1]=A[0][j-1];
        else C[i-1][j-1]=A[i-1][j-1];   
    }
  
}
else
{
    for(int i=1;i<=4;i++);
    for(int j=1;j<=4;j++);
    {
        if(i==1)C[i-1][j-1]=B[IB-1][j-1];
        else if(i==IB)C[i-1][j-1]=B[0][j-1];
        else C[i-1][j-1]=B[i-1][j-1];
    }
}
printf ("IA=%d IB=%d\n\n",IA,IB);
printf ("Massive B\n");
for (int i=1;i<=4;i++)
for (int j=1;j<=4;j++)
{
    if(j==4) printf("%d\n",B[i-1][j-1]);
    else printf ("%d",B[i-1][j-1]);
}
printf ("\n");
printf ("Massiv C\n");
for (int i=1;i<=4;i++)
for (int j=1;j<=4;j++)
if (j==4) printf ("%d\n",C[i-1][j-1]);
else printf ("%d",C[i-1][j-1]);
}
int findMax(int A[4][4],int B[4][4],int IA,int IB);
{
    int maxA=A[0][0];
    int maxB=B[0][0];
    for (int i=1;i<=4;i++)
    for (int j=1;j<=4;j++)
    {
        if(A[i-1][j-1]>maxA)maxA=A[i-1][j-1];
        IA=i;
        {
            if (B[i-1][j-1]>maxB)maxB=B[i-1][j-1];
            IB=i;
        }
    } 
    return IA;
}
int main()
{
    int IA,IB,i,j,B[4][4],A[4][4],check;
    for (int i=1;i<=4;i++)
    for (int j=1;j<=4;j++)
    scanf ("%d".&A[i-1][j-1]);
    for (int i=1;i<=4;i++)
    for (int j=1;j<=4;j++)
    {
        if (i==j)B[i-1][j-1]=A[i-1][j-1]-A[j-1][i-1];
        else B[i-1][j-1]=a[i-1][j-1]+A[j-1][i-1];
    }
    IA=0;
    IB=0;
    findMax(A,B,IA,&IB);
    FormMassive(A,B,IA,IB);
    getch();
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.02.2015, 05:39
Ответы с готовыми решениями:

Помогите найти ошибку в программе
Задание: найти по модулю первый и второй максимальний елемент динамичного массива! Код: ...

Помогите найти ошибку в программе
Помогите мне найти ошибку) Реализовать необходимо на С++ #include &lt;iostream&gt; #include &lt;stdlib.h&gt;...

Помогите найти ошибку в программе! (С++)
Найти строку с минимальной суммой элементов #include&lt;iostream&gt; using namespace std; #include...

помогите найти ошибку в программе
#include &lt;cstdlib&gt; #include &quot;CMatrix.h&quot; #include &lt;conio.h&gt; //Руссификация ostream&amp;...

Помогите найти ошибку в программе
вводятся фамилия имя отчество, определить самое редкое имя. Что не так, почему программа не...

2
Гоблин-инженер
16.02.2015, 06:35
  #2

Не по теме:

NewBayan, вы просто не представляете, какое удовольствие читать никак не отформатированный код (тэги, отступы), да еще и не зная задания к вашей программе. И не жалко вам форумчан?

0
zss
Модератор
Эксперт С++
7096 / 6627 / 4196
Регистрация: 18.12.2011
Сообщений: 17,473
Завершенные тесты: 1
16.02.2015, 07:48 #3
Цитата Сообщение от NewBayan Посмотреть сообщение
for (int i=1;i<=4;i++);
C++
1
for (int i=0;i<4;i++)
И так все циклы.
!!!!!! Убираем также точку с запятой в конце строки.
В индексах массивов убираем -1,
тогда можно будет понять, правильно написано, или нет.

Добавлено через 55 секунд
Цитата Сообщение от NewBayan Посмотреть сообщение
scanf ("%d".&A[i-1][j-1]);
Точку поменяйте на запятую

42 строка
Цитата Сообщение от NewBayan Посмотреть сообщение
int findMax(int A[4][4],int B[4][4],int IA,int IB);
Это описание функции. Убираем точку с запятой в конце строки.

Добавлено через 1 минуту
68 строка -
Цитата Сообщение от NewBayan Посмотреть сообщение
else B[i-1][j-1]=a[i-1][j-1]+A[j-1][i-1];
a меняем на A

Добавлено через 2 минуты
C++
1
int findMax(int A[4][4],int B[4][4],int& IA,int& IB)
IA IB передаем по ссылке.
Вызов соответственно в 72 строке
C++
1
 findMax(A,B,IA,IB);
Добавлено через 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
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
#include <stdio.h>
#include <conio.h>
void FormMassive(int A[4][4],int B[4][4],int IA,int IB)
{
int C[4][4];
if(IA>IB)
{
    for(int i=1;i<=4;i++)
    for(int j=1;j<=4;j++)
    {
        if(i==1)C[i-1][j-1]=A[IA-1][j-1];
        else if(i==IA)C[i-1][j-1]=A[0][j-1];
        else C[i-1][j-1]=A[i-1][j-1];   
    }
  
}
else
{
    for(int i=1;i<=4;i++)
    for(int j=1;j<=4;j++)
    {
        if(i==1)C[i-1][j-1]=B[IB-1][j-1];
        else if(i==IB)C[i-1][j-1]=B[0][j-1];
        else C[i-1][j-1]=B[i-1][j-1];
    }
}
printf ("IA=%d IB=%d\n\n",IA,IB);
printf ("Massive B\n");
for (int i=1;i<=4;i++)
for (int j=1;j<=4;j++)
{
    if(j==4) printf("%d\n",B[i-1][j-1]);
    else printf ("%d",B[i-1][j-1]);
}
printf ("\n");
printf ("Massiv C\n");
for (int i=1;i<=4;i++)
for (int j=1;j<=4;j++)
if (j==4) printf ("%d\n",C[i-1][j-1]);
else printf ("%d",C[i-1][j-1]);
}
int findMax(int A[4][4],int B[4][4],int& IA,int& IB)
{
    int maxA=A[0][0];
    int maxB=B[0][0];
    for (int i=1;i<=4;i++)
    for (int j=1;j<=4;j++)
    {
        if(A[i-1][j-1]>maxA)maxA=A[i-1][j-1];
        IA=i;
        {
            if (B[i-1][j-1]>maxB)maxB=B[i-1][j-1];
            IB=i;
        }
    } 
    return IA;
}
int main()
{
    int IA,IB,B[4][4],A[4][4];
    for (int i=1;i<=4;i++)
    for (int j=1;j<=4;j++)
    {
       printf("input a[%d][%d]:",i,j);
       scanf ("%d",&A[i-1][j-1]);
    }
    for (int i=1;i<=4;i++)
    for (int j=1;j<=4;j++)
    {
        if (i==j)B[i-1][j-1]=A[i-1][j-1]-A[j-1][i-1];
        else B[i-1][j-1]=A[i-1][j-1]+A[j-1][i-1];
    }
    IA=0;
    IB=0;
    findMax(A,B,IA,IB);
    FormMassive(A,B,IA,IB);
    getch();
    return 0;
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
16.02.2015, 07:48

Помогите найти ошибку в моей программе
#include&lt;iostream.h&gt; #include&lt;conio.h&gt; #include&lt;math.h&gt; struct uravn {double a, b, e; void...

Структуры. Помогите найти ошибку в программе
3. Сведения об экзамене содержат следующие данные: дисциплину (программирование, социология,...

Помогите найти ошибку в программе. Вычисление формулы.
Написал программу, которая считает формулу, но она не работает. Компилятор ошибок не выдает, но...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

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