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

Результат функции зависит от ёё расположения в коде О_о - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Задачка на иниересную тему http://www.cyberforum.ru/cpp-beginners/thread948312.html
Доброго времени суток. Решаю олимпиадные задачи по программированию, наткнулся на описанную ниже задачу и не могу понять, с какой стороны к ней подойти... Текст задачи: Через прямоугольник,...
C++ Отсортировать массив методом вставки #include <conio.h> #include <iostream.h> #include <math.h> main() // oboznacheniya peremennih { int n,//kolichestvo elementov ishodnogo massiva m,//kolichestvo elementov massiva znacheniy... http://www.cyberforum.ru/cpp-beginners/thread948298.html
C++ Консольное приложение. Матрицы.Написать и протестировать функции
Написать и протестировать функции вычитания матриц, изменения знака матрицы, формирования единичной матрицы, умножения матрицы слева на ее транспонированную, перестановки двух столбцов матрицы,...
Процедуры и массив (создать, заполнить, вывести, подсчитать количество неубывающих серий) C++
Помогите написать программу. Нужны создать массив ( к примеру 10 элементов) и несколько процедур к нему. 1. Заполнить массив. 2. Вывести его 3. Подсчитать количество неубывающих серий ( т.е...
C++ Направьте на путь истинный!) http://www.cyberforum.ru/cpp-beginners/thread948256.html
Здравствуйте господа и леди форума) Начал я изучать язык программирования с++, выбрал книжку для новичка " Р.Флюре." Ооп в с++, она наверно не для новичка я даже и не знаю)) Но вся соль в том что ни...
C++ сумма элементов матрицы С клавиатуры вводится размерность целочисленной матрицы,затем сама матрица.Найти сумму всех элементов.Разрешается при этом использовать только один оператор цикла(кроме цикла ввода матрицы). Вот... подробнее

Показать сообщение отдельно
Boderman
3 / 3 / 3
Регистрация: 25.03.2013
Сообщений: 140

Результат функции зависит от ёё расположения в коде О_о - C++

04.09.2013, 17:51. Просмотров 312. Ответов 2
Метки (Все метки)

Подскажите студенту пожалуйста в чём у меня косяк (ну кроме ДНК ):

Функция по разному реагирует на расположение в коде .

При вызове функции Bubbles (а точнее очередности вызова параметра Min и Max) расчет верен если ( 1->Max 2->Min ) и
не верен если (1->Min 2->Max):

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
 
#include <iostream>
#include <Windows.h>
using namespace std;
 
int Min (int a, int b)
{
    return a>b;
}
 
int Max (int a, int b)
{
    return a<b;
}
 
void Bubbles(int *d,int n, int (*comp)(int,int))
{int buf=NULL;
    for(int i=1;i<n-1;i++)
    {
       for(int j=0;j<n-i;j++)
               {
                  if (comp ((*(d+j)),(*(d+(j+1)))))
                  {
                     buf=(*(d+j));
                     *(d+j)=(*(d+(j+1)));
                     *(d+(j+1))=buf;
                  }
 
               }  
    }
    
}
 
 
 
void main()
{
    int array_0[]={32,23,2,4,3,2,34,32,2,31,32,43,1221,43,2};
      
    Bubbles(array_0,sizeof(array_0)/sizeof(int),Max);
 
    for (int i=0;i<sizeof(array_0)/sizeof(int);i++)
    {
        cout<<array_0[i]<<"  ";
    }
    cout<<endl; 
    
    Bubbles(array_0,sizeof(array_0)/sizeof(int),Min);
 
    for (int i=0;i<sizeof(array_0)/sizeof(int);i++)
    {
        cout<<array_0[i]<<"  ";
    }
    cout<<endl;
    
   system("pause");
 
}
Добавлено через 39 минут
Немного переделал код но результат тот же.

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
#include <iostream>
#include <Windows.h>
using namespace std;
 
int Min (int a, int b)
{
    return a>b;
}
 
int Max (int a, int b)
{
    return a<b;
}
 
void Bubbles(int *d,int n, int (*comp)(int,int))
{/*int buf=NULL;*/
    for(int i=1;i<n-1;i++)
    {
       for(int j=0;j<n-i;j++)
               {
                  if (comp ((*(d+j)),(*(d+(j+1)))))
                  {
                     /*buf=(*(d+j));
                     *(d+j)=(*(d+(j+1)));
                     *(d+(j+1))=buf;*/
 
                      *(d+j)=(*(d+j))+(*(d+(j+1)));
                      *(d+(j+1))=(*(d+j))-(*(d+(j+1)));
                      *(d+j)=(*(d+j))-(*(d+(j+1)));
 
                  }
 
               }  
    }
    
}
 Комментарий модератора 
Языки программирования не путаем!..
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru