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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Only_HED
4 / 4 / 0
Регистрация: 28.05.2009
Сообщений: 29
#1

Пример из книги не работает. - C++

12.03.2010, 09:20. Просмотров 466. Ответов 4
Метки нет (Все метки)

Пример из книги, тема Классы

но смотрю что нет обращения к Task::swap(int i,int j)

Думаю ошибка именно в Task::sort(int size).

Подскажите пожалуйста.

ниже сам код...

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
#include <iostream>
#include <conio.h>
using namespace std;
 
class Task
{
private: void swap(int,int);
         int array[100];
public: void input();
        void output();
        void sort(int);
};
int N;
void Task::input()
{
    int i;
    for (i=0;i<N;i++)
        cin>>array[i];
}
 
void Task::sort(int size)
{
    int start,i,min_pos,min;
    start=0;
    while (start!=size-1)
    {
        min=array[start];
        min_pos=start;
        for (i=start;i<size;i++)
            if (array[i]<min)
            {
                min=array[i];
                min_pos=i;
            }
            if (min_pos!=start)                         
                start++;
        }
        
}
 
void Task::swap(int i,int j)
{
    int Temp;
    Temp=array[i];
    array[i]=array[j];
    array[j]=Temp;
}
 
void Task::output()
{
    int i;
    for (i=0;i<N;i++)
        cout<<array[i]<<" ";
    getch();
    
}
 
int main()
{
    cin>>N;
    Task object;
    object.input();
    object.sort(N);
    object.output();
}
Миниатюры
Пример из книги не работает.  
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.03.2010, 09:20     Пример из книги не работает.
Посмотрите здесь:

пример из книги страуструпа C++
C++ Пример из книги Лафоре
C++ Непонятный пример из книги
C++ Пример из книги. Шилдт
Простой пример из книги C++
Пример с книги не компилируется! C++
C++ пример из книги
C++ Пример из книги- ну, напутан
Инициализация переменных - некорректно работает пример из книги C++
C++ Лафорье (13глава) - пример из книги, как он есть - не работает
Пример из книги Джесс Либерти не работает(указатели) C++
C++ Не работает пример из книги

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Iworb
анимешник++
 Аватар для Iworb
93 / 60 / 2
Регистрация: 03.11.2009
Сообщений: 411
12.03.2010, 09:52     Пример из книги не работает. #2
а где у вас array заполняется?

Добавлено через 24 секунды
а, все, нашел

Добавлено через 1 минуту
Цитата Сообщение от Only_HED Посмотреть сообщение
Task::sort(int size)
да не, вроде тут все впорядке

Добавлено через 2 минуты
Если вы не уверены, попробуйте добавить в каждую из функций вывод какой-либо строки, так вы точно будете знать, где остановилось это дело.

Добавлено через 1 минуту
Я конечно не уверен, что поможет, но еще попробуйте сюда
C++
1
2
3
4
5
6
7
class Task
{
private: void swap(int,int);
         int array[100];
public: void input();
                void output();
                void sort(int);
добавить конструктор и деконструктор
в ветку public допишите
C++
1
2
Task();
~Task();
Vorona
Peace 2 all shining faces
 Аватар для Vorona
662 / 524 / 44
Регистрация: 05.03.2010
Сообщений: 1,270
12.03.2010, 10:00     Пример из книги не работает. #3
в функции sort() неполадка, она зацикливается, если вводить элементы не в порядке убывания
Black Fregat
 Аватар для Black Fregat
1354 / 984 / 215
Регистрация: 31.05.2009
Сообщений: 4,108
12.03.2010, 10:01     Пример из книги не работает. #4
Я думаю, строчка 35 должна выглядеть так:
C++
1
if (min_pos!=start) swap(min_pos, start);
Или swap на следующей строчке. В книге просто опечатка, а по смыслу программы и по тексту комментариев должно быть так.
Only_HED
4 / 4 / 0
Регистрация: 28.05.2009
Сообщений: 29
12.03.2010, 10:24  [ТС]     Пример из книги не работает. #5
Да ошибка в Task::sort

ВОт как надо

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
void Task::sort(int size)
{
    int start,i,min_pos,min;
    start=0;
    while (start!=size-1)
    {           
        min=array[start];
        min_pos=start;
        for (i=start;i<size;i++)            
            if (array[i]<min)
            {
                min=array[i];
                min_pos=i;
            }
            if (min_pos!=start)
                swap(start,min_pos);
                start++;                
        }
        
}
Yandex
Объявления
12.03.2010, 10:24     Пример из книги не работает.
Ответ Создать тему
Опции темы

Текущее время: 14:17. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru