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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Помогите разобраться 
:(
    Опции темы
Deison
Дата 26.9.2003, 11:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Дана марица A[N][M], определить колличество особых элементов, элемент особый если он больше суммы всех остальных в своем столбце

#include <iostream.h>
#include <conio.h>

void main()
{
int **A,i,j,N,M,k,sum,os;
clrscr();
cout<<"Введите размерность матрицы A[N][M]";
cin>>N>>M;
cout<<"Введите "<<N*M<<" элементов массива";
A=new int*[N];
for(i=0;i<N;i++)
A[i]=new int[M];
for(i=0;i<N;i++)
for(j=0;j<M;j++)
cin>>A[i][j];
cout<<"Контрольный вывод массива \n";
for(i=0;i<N;i++)
{
cout<<"\n";
for(j=0;j<M;j++)
cout<<A[i][j]<<" ";
}
os=0;
for(j=0;j<M;j++)
for(i=0;i<N;i++)
{
sum=0;
for(k=0;k<N;k++)
if(k!=i)
sum+=A[k][j];
if(A[i][j]>sum)
os++;
}

cout<<"\n\n В этой матрице "<<os<<" особых элементов ";
getch();
for(i=0;i<N;i++)
delete A[i];
delete []A;
}

Подскажите пожалуйста как она работает?
Если sum-сумма
os- особый элемент
что такое К?

PM MAIL   Вверх
RAN
Дата 26.9.2003, 18:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Экс. модератор
Сообщений: 709
Регистрация: 14.3.2003
Где: Щёлково Моск.обл.

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



IMHO, плохой алгоритм.
Во-первых, не надо каждый раз пересчитывать сумму элементов в столбце. Достаточно это сделать один раз. А потом сравнивать A[i][j] > sum - A[i][j]
Во-вторых, надо всегда делать математическое обоснование алгоритма. Не надо быть Пифагором, чтоб понять, что такой элемент может быть лишь один в столбце и он будет самым большим элементом. Таким образом надо пройтись по элементам столбца, посчитав их сумму и найдя наибольший, а потом сравнить больше ли этот максимальный элемент половины суммы. Если да, то он - особый элемент.

Цитата
Подскажите пожалуйста как она работает?

Пожалуйста:
Код

#include <iostream.h> //для работы с вводом/выводом
#include <conio.h> //для getch(); и clrscr();

void main()
{
int **A,i,j,N,M,k,sum,os;

clrscr(); //Очищаем экран

cout<<"Введите размерность матрицы A[N][M]";
cin>>N>>M; //Вводим размерность матрицы

cout<<"Введите "<<N*M<<" элементов массива";

/*динамически выделяем под матрицу память */
A=new int*[N];
for(i=0;i<N;i++)
   A[i]=new int[M];

/* Пользователь вводит матрицу */
for(i=0;i<N;i++)
for(j=0;j<M;j++)
   cin>>A[i][j];

/* Заголовок говорит сам за себя */
cout<<"Контрольный вывод массива \n";
for(i=0;i<N;i++)
{
   cout<<"\n";
   for(j=0;j<M;j++)
       cout<<A[i][j]<<" ";
}

os=0; //здесь будем считать кол-во особых элементов
/* Алгоритм подсчёта элементов */
/* ИСПРАВЬ - НЕ ПОЗОРЬСЯ. ЭТО НА ТРОЙКУ ТЯНЕТ. */
for(j=0;j<M;j++)
   for(i=0;i<N;i++)
   {
       sum=0; //Будем считать сумму элементов в столбце
       for(k=0;k<N;k++) //k - это переменная для цикла по всем элементам в столбце
           if(k != i) //Если это не сам элемент A[i][j], то добавить к сумме
               sum+=A[k][j];
       if(A[i][j]>sum) //Проверяем условие "особости"
           os++;
   }

cout<<"\n\n В этой матрице "<<os<<" особых элементов ";

getch(); //Ждем нажатия любой клавиши, чтоб пользователь посмотрел результаты

/* Освобождаем память, отведенную под матрицу */
for(i=0;i<N;i++)
   delete A[i];
delete []A;

}

PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++:Общие вопросы"
Earnest Daevaorn

Добро пожаловать!

  • Черновик стандарта C++ (за октябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика(4.4мб).
  • Черновик стандарта C (за сентябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика (3.4мб).
  • Прежде чем задать вопрос, прочтите это и/или это!
  • Здесь хранится весь мировой запас ссылок на документы, связанные с C++ :)
  • Не брезгуйте пользоваться тегами [code=cpp][/code].
  • Пожалуйста, не просите написать за вас программы в этом разделе - для этого существует "Центр Помощи".
  • C++ FAQ

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

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


 




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


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

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