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

характеристики столбца!!!!! - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Двунаправленный список http://www.cyberforum.ru/cpp-beginners/thread149756.html
Люди, объясните пжлст, что такое двунаправленный список?
C++ Двумерный массив с динамическим выделением памяти Помогите пожалуйста вставить вот в эту вот задачу динамическое выделение памяти: #include <iostream> using namespace std; int main() { const int n=2; int M; http://www.cyberforum.ru/cpp-beginners/thread149752.html
C++ ООП C++
Просьба дать какую-нибудь интересную программу, дабы теста на курс ООП. Чтобы не из книжки, а реально придуманная про программистом, или начинающим) Зоопарк как предложили парню недавно не предлагать, ибо будет неинтересно) Заранее спасибо. Мне нужна только задача, а не сама программа)
[C++] Регулярные выражения C++
Знаю что в стандарте С нет регулярных выражений. Хочу попробывать собрать простую функцию поиска по шаблону регулярных выражений. Аналог int preg_match_all ( string $pattern , string $subject , array &$matches ] ) (шаблон, строка, массив) (pattern,subject,outarray)
C++ Include gurad http://www.cyberforum.ru/cpp-beginners/thread149686.html
В моей программе, при попытке использования сабжа, происходит ошибка. Для проверки я составил следующий код. //hd1.h #ifndef hd1 #define hd1 #include "hd2.h" class hd1 { public:
C++ Как назывался компилятор типаBorland Pascal только для C++ Там такое же синие окошечко было? подробнее

Показать сообщение отдельно
dasha_koks
5 / 5 / 1
Регистрация: 24.06.2010
Сообщений: 19

характеристики столбца!!!!! - C++

27.06.2010, 01:18. Просмотров 352. Ответов 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
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 <iostream>
#include <fstream>
#include <math.h>
#include <iomanip> 
using namespace std;
int main ()
{
ifstream fin("input.txt" , ios::in);
if (!fin)
{ cout<<"File input.txt ne naiden"<<endl; return 1;}
int R, C;
fin >> R >> C;
int **a= new int *[R]; // отводится память под массив ук-лей на строки
int i,j; 
for (i=0; i< R; i++)
a[i] = new int[C]; // выделяется память под строку массива
for ( i=0; i<R; i++) //ввод массива
for( j=0;j<C;j++)
fin>>a[i][j];
 
// Вывод исходного массива на экран
cout<<"Ishodn. massiv:"<<endl;
for( i=0; i<R; i++){
cout<<"\n";
for(j=0; j<C; j++)
cout<<setw(7)<<a[i][j];}
 
// Нахождение характеристик столбцов
int *Sum_H =new int [C]; 
cout<<"\n\n Haracteristiki stolbcov:"<<endl;
for(j=0; j<C;j++) {
Sum_H[j]=0;
for (i=0; i<R; i++) 
if (a[i][j]<0 && (a[i][j]%2)!=0)
Sum_H[j]+= fabs(a[i][j]);
if (Sum_H[j]!=0)
cout<<" Sum_H["<<j<<"]="<<Sum_H[j];}
 
// Упорядочение по возрастанию характеристик
int jmin, buf_Sum_H;
for(j=0; j<C-1; j++) {
jmin=j;
for(int jp=j+1; jp<C; jp++) 
if (Sum_H[jp] < Sum_H[jmin]&& Sum_H[jp]!=0)
jmin=jp;
if (jmin!= j) {
buf_Sum_H= Sum_H[j];
Sum_H[j]=Sum_H[jmin];
Sum_H[jmin]=buf_Sum_H;
for(i=0;i<R;i++){
int buf_a=a[i][j];
a[i][j]=a[i][jmin];
a[i][jmin]=buf_a; } } } 
delete [ ] Sum_H;
 
// Вывод массива с переставленными по возр.хар-к столбцами)
cout<<"\n\n Massiv s perestavlen.stolbcami:\n"<<endl;
for(i=0; i<R;i++){
cout<<"\n";
for(j=0; j<C; j++)
cout<<setw(7)<<a[i][j];}
cout<<endl;
 
// Нахождение суммы эл-тов в столбцах,содерж.хотя бы 1 отр.эл-т
int *Sum=new int[C]; int Pr;
cout<<"\n Summa elementov po stolb. s otr.elem.:\n";
for (j=0; j<C; j++) { 
Sum[j]=0; Pr=0;
for(i=0; i<R; i++)
if (a[i][j]<0) {
Pr=1;break;}
if (Pr==1) {
for(i=0; i<R; i++) 
Sum[j]+= a[i][j]; 
cout<<" Sum["<<j<<"]="<<Sum[j];
} }
cout<<"\n";
return 0;
}
Дело в том, что Характеристиками столбца целочисленной матрицы назовем сумму модулей его отрицательных элементов. так вот дан массив например 3 на 5 -15 элементов:
1 2 -3
4 -3 0
5 -2 -5

и он считает Sum_H[1]=3 а Sum_H[2]=8
т.е. 1 столбца не складывает а второго складывает по модулю
!!!!!!!Помогите это исправить!!!!!!

дальше он выдает так
массив с перестановленными столбцами:
1 2 -3
4 -3 0
5 -2 -5
сумма элементов по столбцам с отрицательными элементами:
Sum_H[1]=3 и Sum_H[2]=8
т.е. ничего не поменялось!!!!!!!!!!!!!
как исправить????????
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru