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

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

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

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

12.03.2010, 09:20. Просмотров 489. Ответов 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++
Я писал код из книжки и ничего не работает. #include &lt;iostream&gt; using namespace std; #include &lt;conio.h&gt; int main(){ ...

Не работает пример из книги Лафоре - C++
Доброго времени суток! Взялся решать задачу из книги Лафоре, глава 9, упр. 2. Опробовал уже готовое решение из самой книги- не работает. ...

Пример из книги Джесс Либерти не работает(указатели) - C++
Занимаюсь С++ по книге Джесс Либерти &quot;Освой самостоятельно С++ за 21 день&quot; В С++ новичок. На 8-ом дне, а вернее на 8-ой теме &quot;указатели&quot;...

Инициализация переменных - некорректно работает пример из книги - C++
Взял задачку из книги Г.Шилда. Должно показывать 1 3 6 10 15. Но у меня выдает 1 2 3 4 5. Набрал всё точь в точь с книги, в чём проблема,...

Лафорье (13глава) - пример из книги, как он есть - не работает - C++
Есть пример в книге Лафорье, в 13 главе (многофайловые программы), называется он vl_app. В программе 3 файла, verylong.h, verylong.cpp,...

Почему не работает программа-пример для демонстрации работы функции strcmp (из книги Шилдта)? - C++
Здравствуйте, помогите пожалуйста разобраться, почему программа не выполняется как надо. Программа-пример, для демонстрации работы функции...

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Iworb
анимешник++
93 / 60 / 2
Регистрация: 03.11.2009
Сообщений: 413
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
668 / 530 / 45
Регистрация: 05.03.2010
Сообщений: 1,276
12.03.2010, 10:00     Пример из книги не работает. #3
в функции sort() неполадка, она зацикливается, если вводить элементы не в порядке убывания
Black Fregat
1381 / 1011 / 222
Регистрация: 31.05.2009
Сообщений: 4,240
12.03.2010, 10:01     Пример из книги не работает. #4
Я думаю, строчка 35 должна выглядеть так:
C++
1
if (min_pos!=start) swap(min_pos, start);
Или swap на следующей строчке. В книге просто опечатка, а по смыслу программы и по тексту комментариев должно быть так.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
12.03.2010, 10:24     Пример из книги не работает.
Еще ссылки по теме:

пример из книги - C++
#include &lt;iostream.h&gt; long summa (int k,...){ int *pik=&amp;k; char *pc=(char *)pik; cout &lt;&lt;&quot; *pc=&quot;&lt;&lt;*pc&lt;&lt;&quot;...

Пример с книги не компилируется! - C++
Павловская Т.С. Пример (программа печатает таблицу значений функции г/=х2+1 во введенном диапазоне): ...

Пример из книги- ну, напутан - C++
Представляте, вчира три часа смотрел на страницу книги- разбирал его, пытался понять... Поначалу ве показалась мне совсем простым.. Дальше...

Пример из книги. Шилдт - C++
Всем привет. Вот пример из книги Шилдта. У меня не работает деструктор (не выводится сообщение) #include &lt;iostream&gt; using namespace...

Непонятный пример из книги - C++
Не могу никак разобраться в одном маленьком примере из книги, речь идёт про условную операцию. Распишите плз, как действует при i=0 i=1 i= 2

пример из книги страуструпа - C++
struct pair { char* name; // ñòðîêà int val; // öåëîå }; const int large = 1024; ...


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

Или воспользуйтесь поиском по форуму:
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     Пример из книги не работает.
Ответ Создать тему
Опции темы

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