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

Нахождение большего числа в массиве - C++

Восстановить пароль Регистрация
 
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.70
Костяныч
15 / 15 / 0
Регистрация: 31.10.2010
Сообщений: 1,225
Записей в блоге: 2
16.11.2010, 14:20     Нахождение большего числа в массиве #1
Доброго время суток друзья. Помогите, исправьте что надо.
Задание такое: Дан массив F: array [1..N,1..M], определить количество"особых" элементов в нем. Элемент считается особым, если он больше суммы остальных элементов своего столбца.
Я побросал код, вроде все так, но не читает как надо!!! Буду признателен за помощь)))
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
#include <stdio.h>
#include <locale.h>
#include <conio.h>
#include <time.h>
#include <stdlib.h>
 
void rand_matr(int **x, int n1, int n2)
{
    srand((unsigned)time(NULL));
    for(int i=0;i<n1;i++)
    {
        for(int j=0; j<n2; j++)
        {
            x[i][j] = rand()%50;
        }
    }
}
 
 
void print_matr (int **x, int n1, int n2)
{
    for(int i=0; i<n1; i++)
      {
        for(int j=0; j<n2; j++)
        {
            printf("%3d", x[i][j]);
        }
        printf("\n");
    }
}
 
int main()
{
  int n,m;
  printf("Vvedite razmer matricy  ");
  scanf("%d%d", &n, &m);
  int **a;
  a = new int *[n];
  for(int i=0; i<n; i++)
  {
     a[i] = new int[m];
  }
 
 rand_matr(a, n, m);
 print_matr(a, n, m);
 
  int sum[999];
  int osobiy=0;
  for(int i=0;i<n;i++)
 { 
    for(int j=0;j<m;j++)
        sum[i]=0;
 }
for(int i=0;i<n;i++)
 { 
    for(int j=0;j<m;j++)
        sum[i]=a[i][j]+sum[i];
 }
 
 
for(int i=0;i<n;i++)
{ 
    for(int j=0;j<m;j++)
    {
        if(sum[i]-a[i][j]<a[i][j])
        {
            osobiy++; 
        }
    }
}
 printf("\n%d", osobiy);
 _getch();
 
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.11.2010, 14:20     Нахождение большего числа в массиве
Посмотрите здесь:

В массиве найти количество нечетных чисел расположенных после второго самого большего числа C++
C++ Нахождение суммы большего и меньшего из 3 чисел (помочь найти ошибку)
Динамический многомерный массив. Нахождение макс. числа, которое в массиве встречаеться более 1 раза. C++
C++ Разложение большего числа на отдельные
C++ Нужно отсортировать значения элементов в массиве от большего к меньшему
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.11.2010, 17:19     Нахождение большего числа в массиве
Еще ссылки по теме:

нахождение наибольшего числа в массиве C++
C++ Запись в фаил бОльшего числа цифр
Нахождение наименьшего числа в массиве C++

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

Или воспользуйтесь поиском по форуму:
Костяныч
15 / 15 / 0
Регистрация: 31.10.2010
Сообщений: 1,225
Записей в блоге: 2
22.11.2010, 17:19  [ТС]     Нахождение большего числа в массиве #21
Вот код, работающий правильно. Но при введении 1 на 1000 появляется ошибка. Помогите решить проблему.
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
#include <stdio.h>
#include <locale.h>
#include <conio.h>
#include <time.h>
#include <stdlib.h>
 
void rand_matr(int **x, int n1, int n2)
{
        srand((unsigned)time(NULL));
        for(int i=0;i<n1;i++)
        {
                for(int j=0; j<n2; j++)
                {
                        x[i][j] = rand()%50;
                }
        }
}
 
 
void print_matr (int **x, int n1, int n2)
{
    for(int i=0; i<n1; i++)
      {
        for(int j=0; j<n2; j++)
                {
                        printf("%3d", x[i][j]);
                }
                printf("\n");
        }
}
 
int main()
{
  int n,m;
  printf("Vvedite razmer matricy  ");
  scanf("%d%d", &n, &m);
  int **a;
  a = new int *[n];
  for(int i=0; i<n; i++)
  {
     a[i] = new int[m];
  }
 
 rand_matr(a, n, m);
 print_matr(a, n, m);
  
  long sum;
  int osobiy;
  osobiy=0;
 
 for(int i=0; i<n; i++)
 {
sum=0;
for(int j=0;j<m;j++)
  {  
     sum=a[j][i]+sum;
  }
 
 for(int j=0;j<m;j++)
  {
     if(sum-a[j][i]<a[j][i])
             osobiy++; 
  }
 }
 printf("\n%d", osobiy);
 _getch();
 
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Yandex
Объявления
22.11.2010, 17:19     Нахождение большего числа в массиве
Ответ Создать тему
Опции темы

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