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

Как из функции взять значение? - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Вычислить и напечатать среднее значение всех введенных чисел http://www.cyberforum.ru/cpp-beginners/thread1002862.html
Числа x1,x2,x3,... последовательно вводятся с клавиатуры. После ввода каждого числа необходимо вычислить и напечатать среднее значение всех введенных чисел:
C++ Написать программу: найти суммы Нужно написать программу, для заданного натурального n и действительного x подсчитать следующие суммы: S=1!+2!+3!+......+n!, где S-сумма, n!- число в факториале. Очень нужно срочно! http://www.cyberforum.ru/cpp-beginners/thread1002861.html
C++ Найти н-й член ряда
Написать программу для нахождения н-ого член ряда
Удаление узла бинарного дерева C++
Товарищи, помогите, пожалуйста, с удалением узла бинарного дерева (метод remove). Один узел удаляется нормально, но после удаления второго узла, дерево ломается, и выскакивает ошибка на методе print. Какая-то беда с указателями. Укажите на ошибку :) #ifndef BINARY_TREE #define BINARY_TREE #include "Error.h" #include <iostream> #include <string> template <class T> class BinaryTree {
C++ Выдает ошибку в любой программе http://www.cyberforum.ru/cpp-beginners/thread1002822.html
Может я не достаточно внимателен, но посмотрите плз в чем дело. Вчера поставил ВС 2012 и теперь в любой программе абсолютно выдает ошибку : MSVCRTD.lib(crtexe.obj) : error LNK2019: ссылка на неразрешенный внешний символ _main в функции ___tmainCRTStartup 1>c:\users\123\documents\visual studio 2012\Projects\Win32Project1\Debug\Win32Project1.exe : fatal error LNK1120: неразрешенных внешних...
C++ Вычисление конечного значения с определённой точностью Добрый вечер, уважаемые программисты. Хочу попросить у вас помощи с программой. Не могу понять, куда привязать точность. Спасибо! подробнее

Показать сообщение отдельно
oleg@tor1
 Аватар для oleg@tor1
32 / 17 / 2
Регистрация: 05.09.2011
Сообщений: 152
09.11.2013, 21: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
#include "stdlib.h"
#include <stdio.h>
#include <iostream> // Ввод/Вывод
#include <cstdlib>  // Для сортировок
#include <time.h>
#include "QS_EDI.h"
using namespace std;
 
void main ()
{
    const int size = 20;            // Размер массива.  
    int array1 [size];              // Массив.
    setlocale(LC_ALL, "Russian");   // Русский тескт.
    srand (time(NULL));             // Генерируем псевдослучайные числа.
    cout << "Данн массив случайных чисел:" << endl << endl;
 
    for (unsigned int i = 0; i < size; ++i)
    {
        array1[i] = rand()% 0xFF;   // Заполняем массив.
        cout << array1[i] << " ";
    }
    cout << endl << endl;
    cout << "Массив после сортировки:" << endl << endl;
 
    QuickSort(array1,0,size-1);
    for (unsigned int i = 0; i < size; ++i)
    {           
        cout << array1[i] << " ";   // Выводим массив.
    } 
    cout << endl << endl;
    cout << "Количество произведённых замен:" << endl << endl;
    
    getchar();
}
+ Заголовочный файл с самой функцией сортировки:
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
#include <iostream>
using namespace std;
 
void QuickSort(int array_1[], int left, int right) // Создаём функцию, принимающую массив и границы (два числа).
{
    int i = left, j = right;                   // Иниц-ем индексы.
    int temp;                                  // Буфер.
    int middle = array_1 [(left + right)/2 ] ; //Находим центральный элемент массива.
    int cnt_ch = 0;                            // Счётчик произведённых замен.
    /*Разделение и сортировка.*/
    while (i < j) {                            // Пока левый меньше правого эл-та.
 
        while (array_1[i] < middle){i++;}      // Пока левый  меньше центрального эл-та следуем слева направо.      
        while (array_1[j] > middle){j--;}      // Пока правый больше центрального эл-та следуем справа налево.  
 
        if (i <= j)                            // Ключевой момент: если i <= j, т.е. эл-ты около центра, то  
        {                                      // меняем их местами.
            temp = array_1[i];
            array_1[i] = array_1 [j];
            array_1[j] = temp;
            i++;
            j--;
            ++cnt_ch;
        }
        /*Рекурсия, т.е. самовызов функции для завершения сортировки.*/
 
        if (left < j)
        {
            QuickSort(array_1, left, j);
        }
 
        if (i < right)
        {
            QuickSort(array_1,i,right);
        }
    }//end_while_1
    
}
Как "забрать" в прогу для отображения "cnt_ch" (стр.9) ?? Через return?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 13:46. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru