Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [C]Двумерный массив, помогите сделать программу 
:(
    Опции темы
TOREN
Дата 24.11.2007, 21:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 29
Регистрация: 5.10.2007

Репутация: нет
Всего: нет



В матрице "А" найти строку с максимальным количеством отрицательных элементов. Предусмотреть возможность отсутствия отрицательных элементов в матрице (вывести сообщение). Найденную строку записать в одномерный массив S.
PM MAIL   Вверх
JAPH
Дата 24.11.2007, 21:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 312
Регистрация: 8.1.2007
Где: Ленобласть

Репутация: 12
Всего: 23



В чём сложность - алгоритм или код?

Это сообщение отредактировал(а) JAPH - 24.11.2007, 22:51


--------------------
Что непонятно - спрашиваем smile
PM MAIL ICQ   Вверх
TOREN
Дата 24.11.2007, 23:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 29
Регистрация: 5.10.2007

Репутация: нет
Всего: нет



лично я не могу реализовать код, алгоритм вроде понятен, но прога работает не верно
PM MAIL   Вверх
Animator
Дата 25.11.2007, 02:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 61
Регистрация: 7.5.2007

Репутация: 1
Всего: 0



Ну вроде бы так:
Код

#include <stdio.h>
#include <stdlib.h>

int Max(int *buf, int count);
int IsEmpty(int *buf, int count);

int main(int argc, char *argv[])
{
  int i, j, count = 0, max;
  int a[4];
  
  int A[4][4] = 
  {
      1,2,3,4,
      2,3,-1,3,
      1,3,4,1,
      1,3,1,5
  };
  
  for(i = 0;i < 4 ;i++)
  {
     for(j = 0; j < 4;j++)
     {
        if(A[i][j] < 0)
        {
           count++;           
        }    
     }
     a[i] = count;
     count = 0;
  }
  
  if(IsEmpty(a, 4))
  {
    printf("This matrix do not contains negative numbers\n");
  }
  else
  {
      max = Max(a,4);
       for(i = 0; i< 4;i++)
       {
             a[i] = A[max][i];
         printf("%d",a[i]);
         printf(" ");
       }
  }
  
  
  system("PAUSE");    
  return 0;
}

int Max(int *buf, int count)
{
    int i;
    int m = 0;
    for(i = 1; i < count; i++)
    {
       if (buf[i] > buf[m]) 
       {
           m = i;
       }
    }
    return m;
}
int IsEmpty(int *buf, int count)
{
    int i,s = 0;
    for(i = 0; i < count; i++)
    {
        s += buf[i];
    }
    if(s)
     return 0;
    else
        return 1;
}


Правда как по мне немного громоздко получилось, но ничего... smile 


Это сообщение отредактировал(а) Animator - 25.11.2007, 02:46
PM MAIL ICQ   Вверх
TOREN
Дата 25.11.2007, 22:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 29
Регистрация: 5.10.2007

Репутация: нет
Всего: нет



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

#include <stdio.h>
#include <stdlib.h>
#define N 10
#define M 10

int Max(int *buf, int count);
int IsEmpty(int *buf, int count);

int main(int argc, char *argv[])
{
float A [N] [M], B[M];
int i, j, n, m, c, count = 0, max, a[N];

do
{
 printf("Vvedite kolichestvo strok [1; %i]: ", N);
 scanf ("%i", &n);
} while ((n>N) || (n<1));

do
{
 printf("Vvedite kolichestvo stolbcov [1; %i]: ", M);
 scanf ("%i", &m);
} while ((m>M) || (m<1));

for (i=0; i<n; i++)
{
  for (j=0; j<m; j++)
  {
   printf("Vvedite A [%i] [%i]: ", i, j);
   scanf("%f", &A [i] [j]);
  }

}
 for(i = 0;i < n ;i++)
  {
     for(j = 0; j < m;j++)
     {
        if(A[i][j] < 0)
        {
           count++;           
        }    
     }
     a[i] = count;
     count = 0;
  }
  
  if(IsEmpty(a, n))
  {
    printf("Eta matrica ne soderzhit otricatel'nih elementov\n");
  }
  else
  {
      max = Max(a,n);
       for(i = 0; i< n;i++)
       {
             a[i] = A[max][i];
         printf("%d",a[i]);
         printf(" ");
       }
  }
  
  
  system("PAUSE");    
  return 0;
}

int Max(int *buf, int count)
{
    int i;
    int t = 0;
    for(i = 1; i < count; i++)
    {
       if (buf[i] > buf[t]) 
       {
           t = i;
       }
    }
    return t;
}
int IsEmpty(int *buf, int count)
{
    int i,s = 0;
    for(i = 0; i < count; i++)
    {
        s += buf[i];
    }
    if(s)
     return 0;
    else
        return 1;

}


PM MAIL   Вверх
Animator
Дата 26.11.2007, 00:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 61
Регистрация: 7.5.2007

Репутация: 1
Всего: 0



Ну вот и хорошо smile . Рад помочь. Обращайся и не забывай подсвечивать код.
PM MAIL ICQ   Вверх
TOREN
Дата 17.12.2007, 22:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 29
Регистрация: 5.10.2007

Репутация: нет
Всего: нет



требуется немного усовершенствовать данную программу так, чтобы в программе происходило динамическое выделение памяти под матрицу(т.е. без заданного размера 10x10) и вычисления были записаны в функцию (хотя это, как мне кажется уже сделано).
исходный код:
Код

#include <stdio.h>
#include <stdlib.h>
#define N 10
#define M 10

int Max(int *buf, int count);
int IsEmpty(int *buf, int count);

int main(int argc, char *argv[])
{
float A [N] [M], B[M];
int i, j, n, m, c, count = 0, max, a[N];

do
{
 printf("Vvedite kolichestvo strok [1; %i]: ", N);
 scanf ("%i", &n);
} while ((n>N) || (n<1));

do
{
 printf("Vvedite kolichestvo stolbcov [1; %i]: ", M);
 scanf ("%i", &m);
} while ((m>M) || (m<1));

for (i=0; i<n; i++)
{
  for (j=0; j<m; j++)
  {
   printf("Vvedite A [%i] [%i]: ", i, j);
   scanf("%f", &A [i] [j]);
  }

}
 for(i = 0;i < n ;i++)
  {
     for(j = 0; j < m;j++)
     {
        if(A[i][j] < 0)
        {
           count++;           
        }    
     }
     a[i] = count;
     count = 0;
  }
  
  if(IsEmpty(a, n))
  {
    printf("Eta matrica ne soderzhit otricatel'nih elementov\n");
  }
  else
  {
      max = Max(a,n);
       for(i = 0; i< n;i++)
       {
             a[i] = A[max][i];
         printf("%d",a[i]);
         printf(" ");
       }
  }
  
  
  system("PAUSE");    
  return 0;
}

int Max(int *buf, int count)
{
    int i;
    int t = 0;
    for(i = 1; i < count; i++)
    {
       if (buf[i] > buf[t]) 
       {
           t = i;
       }
    }
    return t;
}
int IsEmpty(int *buf, int count)
{
    int i,s = 0;
    for(i = 0; i < count; i++)
    {
        s += buf[i];
    }
    if(s)
     return 0;
    else
        return 1;


}

PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.1156 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.