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

Явных ошибок нет, но программа не работает - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Строки - считывание предложений. http://www.cyberforum.ru/cpp-beginners/thread119136.html
Всем привет! Вот такая задача: Написать программу, которая считывает из введенного с консоли текста первые 3 предложения и выводит их в обратном порядке. (предложения содержат <=256 символов) Собственно, интересует вопрос: как считать именно первые 3 предложения?
C++ Матрица В чем ошибка? Как передать матрицу в функцию? //--------------------------------------------------------------------------- #include <vcl.h> #include <iomanip.h> #include <iostream.h> #include <stdlib.h> #include <conio.h> //--------------------------------------------------------------------------- http://www.cyberforum.ru/cpp-beginners/thread119129.html
C++/CLI WinForms Вектор объектов
Надо создать вектор объектов myClass и добавлять туды объекты push_back-ом, как это можно сделать, нужно ли писать конструкторы? И еще, можно ли в данных класса объявить вектор и добавлять туда push_back-ом Например: myClass <vector> x; myClass y; y.tipa_vector.push_back(0); y.tipa_vector.push_back(1); x.push_back(y); подскажите пожалуйста как это можно сделать?
C++ Вопрос о динамическом выделении памяти
Доброго времени суток всем. у меня вопрос к работе следующего кода: delete values; // Удаляем массив из кучи values = temp; // присваиваем адресу адрес нового массива(он тоже в куче находится) temp = 0; // Сбрасываем указатель на массив,который находится в куче мне вот что кажется неестественным: -когда мы...
C++ Шаблон для односвязного списка http://www.cyberforum.ru/cpp-beginners/thread119044.html
Доброго времени суток! Проблема - пишу шаблон для односвязного списка На приведенном фрагменте дает ошибку - " 45 D:\C++\test.cpp expected constructor, destructor, or type conversion before '*' token " 45 D:\C++\test.cpp expected `;' before '*' token Может кто подскажет в чем дело? #include <conio.h> #include <string.h> #include <iostream>
C++ Простое диалоговое окошко main.h: #define IDC_STATIC 100 BOOL CALLBACK DlgProc(HWND, UINT, WPARAM, LPARAM); void DlgOnCommand(HWND, int, HWND, UINT); BOOL DlgOnInitDialog(HWND, HWND, LPARAM); main.cpp: подробнее

Показать сообщение отдельно
paradox92
 Аватар для paradox92
0 / 0 / 0
Регистрация: 27.02.2010
Сообщений: 38
19.04.2010, 19:28     Явных ошибок нет, но программа не работает
Задание было такое:
1. Разработать программу, которая создает массив, количество элементов которого задается пользователем. Все элементы генерируются псевдослучайной последовательностью от 0 до числа, которое задается пользователем с клавиатуры. Программа имеет выводит массив к сортировке и после (осуществить с помощью функций). Сортировка реализовать с помощью блочного метода.
2. К этой программы реализовать поиск элемента с помощью метода дихотомии.

Программа почти готова, только если попадается элемент массива равный "0", то программа даёт сбой. Уже пробовал в функции сортировки "0" поменять на "-1" -- программа запускается, выводит начальные элементы, но потом даёт сбой.
У кого какие идеи как это исправить?

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
#include <iostream.h>
#include <iomanip.h>
#include <time.h>
 
int Bin_Poisk(int M[], int , int );
void Vivod_Massiva ( int b[], int  );
void Bloch_Sort(int ar[], int sze);
 
int main()
{
    int kolichestvo_chisel, kol_iter,  i, gran_mas, k, result;
        cout << "vvedit' kilkist chisel= ";
        cin >> kolichestvo_chisel;
        cout << "vvedit' granicu= ";
        cin >> gran_mas;
        kol_iter = kolichestvo_chisel - 1;
        int a[kolichestvo_chisel];
        srand(time(NULL));
        for (i=0; i!=kolichestvo_chisel; i++)
                a[i] = rand() % (gran_mas + 1);
        cout << "Vivod Massiva Do Sortirovki: " << endl;
        Vivod_Massiva ( a , kolichestvo_chisel);
        cout << "Vivod Massiva Posle Sortirovki: " << endl;
        Bloch_Sort(a, kolichestvo_chisel);
        cout <<"\n";
        cout << "vvedite iskomiy element: ";
        cin >> k;
        result = Bin_Poisk(a, kolichestvo_chisel, k);
        cout << "naiden v elemente massiva " << result << endl;
        return 0;
}
void Vivod_Massiva ( int b[], int mas1 )
{
        for ( int p=0; p!=mas1; p++ )
        cout << setw(4) << b[p];
    cout << "\n";
}
void Bloch_Sort(int ar[], int sz)
{
   const int Rasryad = 10;
   const int Position = 10000;
   int Vremen_mas[Rasryad][Position] = {-1};
   int  number = 1, Ras;
   // Распределяющий проход
   for( int i = 0; i < 5; i++) // Проход столько, сколько разряда у числа
   {
       for( int j = 0; j < sz; j++) // Проход столько, сколько чисел в массиве
       {
           Ras = ar[j] / number % 10; // Вычисление позиции разряда
           Vremen_mas[Ras][j] = ar[j]; // Расположение соответсвенно разряду
        }
       // Собирающий проход после каждого распределяющего
      int counter = 0;
       for( int a = 0; a < Rasryad; a++)
       {
           for( int b = 0; b < Position; b++)
             {
               if (Vremen_mas[a][b] != -1)
                 {
                  ar[counter++] = Vremen_mas[a][b];
                  Vremen_mas[a][b] = -1;
                  }
              }
        }
       number *= 10;
     }
 
    for(int i = 0; i < sz; i++)
      cout<<setw(4)<<ar[i];
}
int Bin_Poisk(int M[], int mas1, int k)
{
    int L = 0;
    int R = mas1;
    int m;
        if(k == M[0])
                return 0;
    while (L<R)
    {
        m = (L+R)/2;
        if (k > M[m]) L = m;
        if (k < M[m]) R = m;
        if (k == M[m]) break;
    }
        return m;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 22:10. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru