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

Код неправильно определяет седловую точку - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Сортировка данных http://www.cyberforum.ru/cpp-beginners/thread701022.html
#include <iostream> using namespace std; char shift(char *in) { char item, *out = in; item = in; *in++; while (*out++ = *in++); return item;
C++ Вывести в документе PDF русские буквы Необходимо написать программный код для решения следующей задачи: вывести в PDF-документе русские буквы. Для этого необходимо задать шрифт с кодировкой Windows 1251. http://www.cyberforum.ru/cpp-beginners/thread701012.html
C++ Класс Matrix, Перегрузка
День добрый... У нас есть класс матрица (NxM), нужно сделать перегрузку "+", со статик матрицой всё работало прекрасно...но после переделки под динамическую, перестало...даже вывод перестал работать, подскажите пожалуйста, где ошибка( #include <iostream> #include <Windows.h> #include <cstdlib> using namespace std; typedef double T; class Matrix { private: T **arr;
Дан массив размера N. Утроить в нем вхождения всех элементов с нечетными номерами C++
Всем привет! Есть такая задачка Дан массив размера N. Утроить в нем вхождения всех элементов с нечетными номерами (1, 3...). Условный оператор не использовать. и как её решить не знаю... Если б не было условия, что надо без условного оператора, может быть и сама решила, а так... не могу=( Очень надеюсь на вашу помощь=)
C++ Не могу открыть файл OFSTREAM http://www.cyberforum.ru/cpp-beginners/thread700976.html
Доброго времен суток! Помогите разобраться: пытаюсь открыть файл с параметром ios::out, а он не открывается :( Почему это может происходить? Код: input.open(name, ios::in||ios::binary); output.open(cpath, ios::out||ios::binary); if(!input) cout<<"Input file opening error"<<endl; if(!output) cout<<"Output file opening error"<<endl; где cpath - массив типа char содержащий путь к файлу...
C++ Нахождение определителя Условие: Написать функцию для вычисления определителя матрицы произвольной размерности способом разложения по элементам строки/столбца. Вот мой вариант(немного исправил условие под себя): #include <cstdio> #include <conio.h> double Det(double** Mat, int N); int main() { double** arr; подробнее

Показать сообщение отдельно
flatra
0 / 0 / 0
Регистрация: 03.11.2012
Сообщений: 343
18.11.2012, 16:16     Код неправильно определяет седловую точку
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
#include "stdafx.h"
#include <ctime>
#include <cstdlib>
#include <iostream>
#include <conio.h>
#include <stdio.h>
using namespace std;
 
 
int main ()
{ 
srand((unsigned)time(NULL));
setlocale(LC_ALL,"rus");
int i, j, n, m, jmax, imin,sum=0,imax,jmin,k;
int **mas = NULL;
 
cout « "Введите колличество строк n=";
cin » n;
cout « "Введеите колличество столбцов m = ";
cin » m;
 
//Выделяем память под матрицу
//Выделяем память под массив строк матрицы
mas = new int*[n];
for (i = 0; i < n; ++i)
{
//Выделяем память под каждую строку матрицы
mas[i] = new int[m];
for (j = 0; j < m; ++j)
{
mas[i][j] = rand()%201-100; //Заполнение матрицы случайными числами в диапазоне от -100 до 100
cout « mas[i][j] « "\t";
}
 
cout « "\n";
}
 
cout « "\n"; 
 
bool bFlag;
for (int i=0; i < n; ++i){
bFlag=false;
for (int j=0; j < m; ++j){
if(mas[i][j]<0){
bFlag=true; break;
}
}
if (bFlag){
for (int j=0; j < m; ++j)
sum += mas[i][j];
}
}
printf("\nсуммa элементов в тех строках, которые содержат хотя бы один отрицательный элемент =%d",i,sum);
printf("\n\nSedlovaia to4ka");
 
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
{
//ищем минимум в строке, т.е. индекс столбца
jmin=0;
for(k=1;k<m;k++)
{
if(mas[i][k]<mas[i][jmin]) jmin=k;
}
//ищем максимум в столбце, т.е. индеск строки
imax=0;
for(k=1;k<n;k++)
{
if(mas[k][j]>mas[imax][j]) imax=k;
}
if((imax==i)&&(imax==j)) printf("%s%d%s%d%s%d%s","Saddle point at [",i,";",j,"]=",mas[i][j],".\n");
else
{
//ищем максимум в строке, т.е. индекс столбца
jmax=0;
for(k=1;k<m;k++)
{
if(mas[i][k]>mas[i][jmax]) jmax=k;
}
//ищем минимум в столбце, т.е. индеск строки
imin=0;
for(k=1;k<n;k++)
{
if(mas[k][j]<mas[imin][j]) imin=k;
}
if((imin==i)&&(jmax==j)) printf("%s%d%s%d%s%d%s","Saddle point at [",i,";",j,"]=",mas[i][j],".\n");
}
}
}
 
 
 
//Удаление матрицы из памяти
//Удаление каждой строки матрицы
 
for (i = 0; i < n; ++i)
delete[] mas[i];
 
//Удаление массива строк матрицы mas
delete[] mas;
 
_getch();
 
}
Добавлено через 2 часа 8 минут
где ошибка
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 16:51. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru