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

Дана квадратная матрица A порядка n. Получить матрицу AB; элементы матрицы B вычисляются по формуле - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Дружественные функции и классы http://www.cyberforum.ru/cpp-beginners/thread112654.html
Доброго времени суток ! Может у кого - нибудь есть похожие исходники или мысли по поводу данного задания ?! Помогите пожалуйста ! Задание 1. Создать класс вещественных с двойной точностью чисел. Класс имеет конструктор по умолчанию, конструктор – преобразующий double в объект класса. Определить оператор преобразования объекта типа вещественных чисел с двойной точностью в...
C++ Рекурсия. Комбинаторика. Размещения Дана задача: вывести все размещения из n по k, где n - это число элементов конечного множества (например, задаваемого из файла). Комбинации считаются различными, если отличаются либо элементами, либо их порядком. Программа должна работать для любого n. Например: Пусть множество (1, 2, 3). Пусть k=2. А n=3. Размещения тогда: 1 2 1 3 2 1 2 3 3 1 http://www.cyberforum.ru/cpp-beginners/thread112626.html
C++ квадратная матрица
по практике дали, не могу сделать( Для заданной квадратной матрицы порядка n поменять местами элементы главной и побочной диагоналей. Найти сумму элементов в четных строках, расположенных ниже главной диагонали. Добавлено через 42 секунды кто сможет помогите))
Упорядочить строки матрицы по неубыванию их первых элементов C++ Builder
вот задача: Дана матрица размером NxM. Упорядочить ее строки по неубыванию их первых элементов. вот кусок программы на си булдер : не пойму почему прога зависает при выполнении этой процедуры((( уважаемые программисты помогите советом //--------------------------------------------------------------------------- void __fastcall TForm1::Button2Click(TObject *Sender) { int min,m,l ;
C++ Читать с консола и записать в файл http://www.cyberforum.ru/cpp-beginners/thread112577.html
что здесь не так? #include <cstdlib> #include <iostream> #include <fstream> using namespace std; int main() { ofstream my_tekst("my_text.txt");
C++ int main() или int main(void)? Показать, что функция не принимает никаких аргументов можно с помощью void. В языке С++ (не в С) принятно, что пустые скобки равнозначны void. (В языке С пустые скобки означают что вы ничего не собщаете о наличии аргументов ) чем отличается : не сообщаю о наличии аргументов функция не принимает никаких аргументов....... подробнее

Показать сообщение отдельно
robert19
25 / 25 / 3
Регистрация: 26.03.2010
Сообщений: 305
07.04.2010, 09:22  [ТС]     Дана квадратная матрица A порядка n. Получить матрицу AB; элементы матрицы B вычисляются по формуле
Цитата Сообщение от Voron8 Посмотреть сообщение
тип матрицы А (int,float,double)?
Делай как лучше будет)))

Добавлено через 5 часов 55 минут
Парни ну помогите кто нить

Добавлено через 5 часов 37 минут
Парни погодите кто нить плиз((((

Добавлено через 18 часов 55 минут
Парни нацдите ошибку плиз, ответ что то не хороший выдает

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
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
#include <stdlib.h>
#include <stdio.h>
#include <time.h>
#include <signal.h>
#include <math.h>
#include <malloc.h>
#include <cstring>
#include <limits>
 
 
 
int new_array(double *** matrix, unsigned long int w,unsigned long int l){
    *matrix = new double* [w];
    if (!*matrix) return 6;
    for (unsigned long int i=0; i<w; i++){
        *(*matrix+i)=new double [l];
        if (!*(*matrix+i)) return 6;
    }
    return 0;
}
 
int del_array (double *** matrix,unsigned long int w){
    for (unsigned long int i=0;i<w; i++)
        delete[] *(*matrix+i);
    delete[] *matrix;
 
    return 0;
}
 
int print_array_console(double ** matrix, unsigned long int w,unsigned long int l){
    for (unsigned long int i=0;i<w;i++){
        for (unsigned long int j=0;j<l;j++){
            printf("|%lf|",*(*(matrix+i)+j));
        }
        printf("\n");
    }
    return 0;
}
 
int read_array_console(double *** matrix, unsigned long int* w,unsigned long int* l){
    int temp,debugger;
    printf("enter height:\n");
    temp=scanf("%lu",w);
    if (temp!=1) return 11;
    printf("enter length:\n");
    temp=scanf("%lu",l);
    if (temp!=1) return 11;
    debugger=new_array(matrix,*w,*l);
    if (debugger) return debugger;
    for (long unsigned int i=0;i<*w;i++){
        for (long  unsigned int j=0;j<*l;j++){
            printf("Enter element with i=%lu, j=%lu\n",i,j);
            temp = scanf("%lf",(*(*matrix+i)+j));
            if (temp!=1) return 11;
        }
    }
    return 0;
}
 
 
 
int read_array_file(double *** matrix, unsigned long int* w,unsigned long int* l){
    int temp,debugger;
    char fn[255];
    FILE *inp=NULL;
    printf("Enter filename: \n");
    temp=scanf("%s",fn);
    if (temp!=1) return 11;
    inp =fopen(fn,"r");
    if (!inp) return 11;
    temp=fscanf(inp,"%lu %lu",w,l);
    if (temp!=2) return 11;
    debugger=new_array(matrix,*w,*l);
    if (debugger) return debugger;
    for (unsigned long int i=0;i<*w;i++){
        for (unsigned long int j=0;j<*l;j++){
            temp = fscanf(inp,"%lf",(*(*matrix+i)+j));
            if (temp!=1) return 11;
        }
    }
    fclose(inp);
    return 0;
}
 
int print_array_file(double ** matrix, unsigned long int w,unsigned long int l){
    int temp;
    char fn[255];
    FILE *outp=NULL;
    printf("Enter filename: \n");
    temp=scanf("%s",fn);
    if (temp!=1) return 11;
    outp =fopen(fn,"w");
    if (!outp) return 11;
    for (unsigned long int i=0;i<w;i++){
        for (unsigned long int j=0;j<l;j++){
            fprintf(outp,"%lf ",*(*(matrix+i)+j));
        }
        fprintf(outp,"\n");
    }
    fprintf(outp,"\n");
    fclose(outp);
    return 0;
}
 
inline int multiple_element(double ** matrix,double ** matrix2,unsigned long int w,unsigned long int i,unsigned long int j,double* result){
    for (unsigned long int k=0;k<w;k++){
        *result+=(*(*(matrix+i)+k))*(*(*(matrix2+k)+j));
    }
    return 0;
}
 
int matrix_fun (double ** matrix,unsigned long int w,double ** result){
    double **b=0;
    int debugger=0;
    debugger = new_array(&b,w,w);
    if (debugger) return debugger;
    for (unsigned long int i=0;i<w;i++){
        for (unsigned long int j=0;j<w;j++){
            b[i][j]=1/(abs(i+j)+1);
        
        }
    }
 
    for (unsigned long int i=0;i<w;i++){
        for (unsigned long int j=0;j<w;j++){
            multiple_element(matrix,b,w,i,j,(*(result+j)+i));
        }
    }
    del_array(&b,w);
    return 0;
}
 
 
int main_fun(){
    unsigned long int w,s,temp=0,debugger;
    double **matrix=0;
    double **result=0;
    printf("What mode are you want? (type 0 to console (default),1 to file)");
    temp = scanf("%lu",&s);
    if (temp!=1) return 11;
    if (s==1) {
        debugger=read_array_file(&matrix,&w,&temp);
    }
    else {
        debugger=read_array_console(&matrix,&w,&temp);
    }
    if (debugger) return debugger;
    if (w!=temp) return 11;
    debugger = new_array(&result,w,w);
    if (debugger) return debugger;
    matrix_fun(matrix,w,result);
    if (s==1) {
        debugger=print_array_file(result,w,temp);
    }
    else {
        debugger=print_array_console(result,w,temp);
    }
    if (debugger) return debugger;
    return 0;
}
 
int main(){
    int a;
    a=main_fun();
    if (a==6) printf("Memory allocation error");
    if (a==11) printf("Data error");
    return a;
}
Добавлено через 19 часов 42 минуты
Неужели никто не может проверить?? Тут програмеров столь, ну проверте плиз
 
Текущее время: 09:18. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru