Форум программистов, компьютерный форум, киберфорум
Наши страницы

не понятно - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Программа для расчёта по двум формулам http://www.cyberforum.ru/cpp-beginners/thread376862.html
Задание:Написать программу для расчёта по двум формулам Формулы: z1=(sin(2a)+sin(5a)-sin(3a))/((cos(a)-cos(3a)+cos(5a)); z2=tg(3a);
C++ Помогите решить в С++ Array18. Дан целочисленный массив размера N. Определить максимальное количество его одинаковых элементов. Matrix18. Дана целочисленная матрица размером M×N. Вывести номер ее первой строки,... http://www.cyberforum.ru/cpp-beginners/thread376861.html
C++ java ----> C++
Как с кода на Java получить С++?
C++ Множество через двусвязный список.
Необходимо реализовать класс множество через двусвязный список. Но проблема у меня стоит в том, что тему списки я не очень понял, когда проходили это на лекции (в отличии от стека и очереди). У...
C++ Запустить вывод файла на экран в отдельном процессе http://www.cyberforum.ru/cpp-beginners/thread376848.html
Программа,запускающая вывод файла на экран в отдельном процессе
C++ Какая операция быстрее, постинкремент, или преинкремент? какая операция быстрее: постинкремент, или преинкремент? и почему? как их можно записать на ассемблере? подробнее

Показать сообщение отдельно
takewa
10 / 7 / 1
Регистрация: 15.08.2010
Сообщений: 372

не понятно - C++

03.11.2011, 00:33. Просмотров 358. Ответов 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 <cmath>
using namespace std;
int main ()
{
        int **mas, n, m, i, j, j1; 
        double  dva, ras, summa;
                cout<<"storko: "<< endl;cin>>n;
                if (n<0) cout<<"error"<<endl;
        else
                cout<<"\nstolbci "<< endl;
        cin>>m;
                if (m<0) cout<<"error"<<endl;
        else
                mas=new int*[n]; 
        for(i=0; i<n; i++)
                mas[i]=new int[m];
        cout<<"\nelementi: "<< endl;
                for(i=0; i<n; i++)
                for(j=0; j<m; j++)
       {
          cout<<"["<<i+1<<"]["<<j+1<<"]= ";
          cin>>mas[i][j];
       }
        cout<<"\nMatrice"<<endl;
                for(i=0; i<n; i++)
        {
        for(j=0; j<m; j++)
           {
          cout<<mas[i][j];
           }
          cout<<endl;
        }
    for(j=0; j<m-1; j++)
       for(j1=0; j1<m-1-j; j1++)
           {
                   ras=dva=0;
                   for(i=0; i<n; i++)
                   {
                           if(mas[i][j1]<0 && mas[i][j1]%2==1)
                                   dva+=abs(mas[i][j1]);
                           if(mas[i][j1+1]<0 &&  mas[i][j1+1]%2==1)
                                   ras+=abs(mas[i][j1+1]);
                   }
                   if(dva>ras)
                           for(i=0; i<n; i++)
                           {
                                   dva=mas[i][j1];
                                   mas[i][j1]=mas[i][j1+1];
                                   mas[i][j1+1]=dva;
                           }
           }
        cout<<"Novaya matrica"<<endl;
    for(i=0; i<n; i++)
        {
       for(j=0; j<m; j++)
           {
          cout<<mas[i][j]<<'\t';
           }
          cout<<endl;
        }
        cout<<endl;
 for(i=0; i<m; i++)
    {
         summa=0;
       
       for(j=0; j<n; j++)
           {
                   summa+=mas[j][i];
                   if(mas[j][i]<0);
                           
           }
           cout<<"Stolbec"<<i+1;
                cout<<"Summa"<<summa<<endl;
              
 }
        system("pause");
    return 0; 
}
характеристикой столбца целочисленной матрицы назовем сумму модулей его отрицательных не четных элементов. Переставляя столбцы заданной матрицы, расположить их в соответствии с ростом характеристик. Найти сумму элементов в тех столбцах,которые содержат хотя бы один отрицательный элемент.
C++
1
2
3
4
if(mas[i][j1]<0 && abs(mas[i][j1])%2==-1)
                                   temp+=abs(mas[i][j1]);
                           if(mas[i][j1+1]<0 && abs(mas[i][j1+1])%2==-1)
                                   temp1+=abs(mas[i][j1+1]);
Мне сказали в этом кусочке программы изменить 1 на -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
80
81
82
83
84
85
86
87
88
89
90
91
#include <iostream.h>
#include <math.h>
#include <windows.h>
char*Rus(const char*text);
char bufRus[256];
char*Rus(const char*text){
CharToOem(text,bufRus);
return bufRus;
}
int main (){
        int **mas, n, m, i, j, j1, temp, temp1, sum;
        bool fl;
                cout<<Rus("Введите количество строк матрицы: ")<< endl;
    cin>>n;
                if (n<0) cout<<Rus("Ошибка")<<endl;
        else
                cout<<Rus("\nВведите количество столбцов матрицы: ")<< endl;
        cin>>m;
                if (m<0) cout<<Rus("Ошибка")<<endl;
        else
                mas=new int*[n]; 
        for(i=0; i<n; i++)
                mas[i]=new int[m];
        cout<<Rus("\nВведите элементы матрицы: ")<< endl;
                for(i=0; i<n; i++)
                for(j=0; j<m; j++)
       {
          cout<<"["<<i+1<<"]["<<j+1<<"]= ";
          cin>>mas[i][j];
       }
        cout<<Rus("\nИсходная матрица")<<endl;
                for(i=0; i<n; i++)
        {
        for(j=0; j<m; j++)
           {
                   cout.width(4);
          cout<<mas[i][j];
           }
          cout<<endl;
        }
    for(j=0; j<m-1; j++)
       for(j1=0; j1<m-1-j; j1++)
           {
                   temp1=temp=0;
                   for(i=0; i<n; i++)
                   {
                           if(mas[i][j1]<0 && abs(mas[i][j1])%2==1)
                                   temp+=abs(mas[i][j1]);
                           if(mas[i][j1+1]<0 && abs(mas[i][j1+1])%2==1)
                                   temp1+=abs(mas[i][j1+1]);
                   }
                   if(temp>temp1)
                           for(i=0; i<n; i++)
                           {
                                   temp=mas[i][j1];
                                   mas[i][j1]=mas[i][j1+1];
                                   mas[i][j1+1]=temp;
                           }
           }
        cout<<Rus("\nПолученная матрица")<<endl;
    for(i=0; i<n; i++)
        {
       for(j=0; j<m; j++)
           {
                   cout.width(4);
          cout<<mas[i][j];
           }
          cout<<endl;
        }
        cout<<endl;
 for(i=0; i<m; i++)
    {
         sum=0;
         fl=true;
       for(j=0; j<n; j++)
           {
                   sum+=mas[j][i];
                   if(mas[j][i]<0)
                           fl=false;
           }
           cout<<Rus("в столбце ")<<i+1;
                
             if(!fl)
                 cout<<Rus(" есть орицательный элемент и сумма его элементов равна ")<<sum<<endl;
                 else
                 cout<<Rus(" нет отрицательного элемента")<<endl;  
 }
        cout<<endl;
        system("pause");
    return 0; 
}
Только в ней вот так вот:
Характеристикой столбца целочисленной матрицы назовем сумму модулей его отрицательных элементов. Переставляя столбцы заданной матрицы, расположить их в соответствии с ростом характеристик. Найти сумму элементов в тех столбцах,которые содержат хотя бы один отрицательный элемент.

Добавлено через 3 часа 35 минут
Народ помогите плиз, завтра защищаться, а я не знаю как нечетные взять
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru