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

Массив - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Задача коммивояжёра http://www.cyberforum.ru/cpp-beginners/thread584593.html
Как решить задачу коммивояжёра методом ветвей и границ. Необязательно писать код, буду рад словесному объяснению.
C++ Массив Задача День добрый! Помогите с массивом решить задачу Дан массив размера N. Найти номера двух ближайших по значению элементов из этого массива (то есть элементов с наименьшим модулем разности) и вывести эти номера в порядке возрастания. Спасибо заранее!!!! http://www.cyberforum.ru/cpp-beginners/thread584592.html
C++ Массив. Заполнение (Горка)
Ещё раз здравствуйте! Помогите с массивом. Заполнить массив «горкой» {1, 4, 5, 8, ... ,7 ,6 ,3 ,2} Заранее спасибо!!!!
C++ Цифры и циклы
День добрый! помогите с решением. Вывести все числа до N, для которых само число равно сумме квадратов цифр этого числа. Если таких чисел нет, сообщить об этом Заранее спасибо решение на С++
C++ По заданному n необходимо вычислить G http://www.cyberforum.ru/cpp-beginners/thread584567.html
...Может показаться простым. По заданному n необходимо вычислить G. Значение G вычисляется следующим образом: Через GCD(i, j) обозначено наибольший общий делитель целых чисел i и j. G = 0; for(i = 1; i < n; i++) for(j = i + 1;j <= n; j++) { G += GCD(i,j); } /*Функция GCD() вычисляет наибольший общий делитель двух чисел*/ Я решил его так:
C++ Класс для строк. Реализация, сравнивание, копирование, конкатенация Помогите пожалуйста создать класс для строк. Реализация, сравнивание, копирование, конкатенация. Через указатели и массивы символов. String использовать нельзя. подробнее

Показать сообщение отдельно
Oasis
 Аватар для Oasis
0 / 0 / 0
Регистрация: 17.01.2012
Сообщений: 18
23.05.2012, 20:09     Массив
Помогите пожалуйста сделать массивы zx, zb,zla динамическими. Большое спасибо.

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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
    #include "stdafx.h"
    #include <iostream>//i/o
    #include <conio.h> //getch
    #include <cmath>   //fabs, abs
    #include "stdafx.h"
    #include <math.h>
    #include <tchar.h> 
 
using namespace std;
 
 
 
     const int zn=2000;
     double zeps = 0.01;
     int zi;
     double zx[zn];
     int zr;
     double zb[zn];
     double zla[zn][zn];
   int vibs;
    
   double Zeydel (double zla[zn][zn], double zb[zn], double zx[zn], double ze);
    
 
    int main () {
    char vibormetoda;
    setlocale (LC_ALL, "Russian"); 
    
                cout<<"Вы выбрали метод Зейделя";
                cout << '\n'; 
 
                std::cout << "Введите NUM уравнений:";
                std::cin >>  zr;
            
         for (int zi = 0; zi < zr; zi++)
            for (int zj = 0; zj < zr; zj++)
            {{
                 std::cout << "Заполните матрицу A [" << zi+1 << "][" << zj+1 << "] = ";
                std::cin >> zla[zi][zj];
            
            }}
            for (int zi = 0; zi < zr; zi++) {
                std::cout << "Вектор B [" << zi << "] = ";
                std::cin >> zb[zi];
            }
 
            // Выводим матрица и вектор 
 
                cout<<("Матрица А\n");
    
        for (int i = 0; i<zr; i++)
        {
            for(int j = 0;j<zr; j++)
                cout<<zla[i][j]<<"\t";
            
            cout<<"\n";
        }
        
        printf("Вектор B\n");
           for (int i = 0; i<zr; i++){
        cout<<zb[i]<<"\n";
           }
 
        
            cout << '\n'; 
            
 
     for (int zi=0;zi<zr;zi++)
     {
      zx[zi]=0;
     }
 
     if (Zeydel (zla,zb,zx,zeps))
     {
         cout << '\n'; cout << '\n'; 
         std::cout<<"Результат";
         cout << '\n'; cout << '\n'; 
      for (int zi=0;zi<zr;zi++)
      {
       std::cout<<zx[zi]<< ' ';
      }}   
 
    
            
   system ("Pause");
    
 
        }
        
 
    //____________________Зейдель
 
    double Zeydel (double zla[zn][zn], double zb[zn], double zx[zn], double ze)
    {
     int zi,zj;
     double zs1, zs2, zs, zv, zm;
    double zii=0;
     do
     {
      zm = 0;
      for (zi=0; zi< zr; zi++)
      {
       zs1=0;
       zs2=0;
 
       for (zj=0;zj<zi;zj++)  zs1+= zla[zi][zj]*zx[zj];
       for (zj=zi;zj<zr;zj++)  zs2+= zla[zi][zj]*zx[zj];
        zv=zx[zi];
        zx[zi]-=(zs1+zs2-zb[zi])/zla[zi][zi];
 
        if (fabs(zv-zx[zi])>zm)
         zm=fabs(zv-zx[zi]);
       }
        zii++;
       }
      while (zm>=ze);
 
        std::cout<<"Число интерации "<<zii;
       return 1;
     }
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 09:50. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru