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

Ошибки после компиляции - C++

Восстановить пароль Регистрация
 
DDT
Сообщений: n/a
07.10.2009, 22:03     Ошибки после компиляции #1
Дана задача(дословно): дан массив целых положительных чисел, переписать простые числа во второй массив; упорядочить массивы 1-й по возрастанию 2-й по убыванию. Создать функции для определения простого числа и для сортировки.
Писал на C++ Builder 2007 (пробовал на других компах: под Windows 7 в VS 2009 тоже кието ошибки и под XP тоже на C++ Builder 2007) компилируется без ошибок и предупреждений, затем вылазит много всякого.
Т.к. после работы я мало чего понимал на парах потеряв почти весь день получилось следующее:
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
#include <vcl.h> //как я понял обязателен
#include <iostream.h>
#include <math.h>
 
using namespace std;
int m[50], mc[50]; //массивы
//-Заполнение массива рандомом-----------------------------------------------
    void ZapMas(int n)
 {
  randomize();
  for(int i=0; i<50; i++)
  m[i]=1 + rand()%100;
  }
//-Определенеие простого числа по теореме Вильсона---------------------------
long int factorial(int x)//функция находит факториал рекурсивным методом
 {
    return(x * factorial (x - 1));
 }
bool SimpleInt (int p)//считает логическое выражение и возвращает false,
                //если число составное, true, если число простое
 {
  return ((factorial (p-1)+1)%p==0);
 }
//-копирование простых чисел-------------------------------------------------
void CopyPCh(int n)
 {
    for (int i = 0; i < n; i++) {
    if (SimpleInt(m[i]) == true) {mc[i] = m[i];}
    }
 }
//-сортировка по методу пузырька по возвростанию-----------------------------
  void SortV(int n)
  {
  int i, j, b;
  for( i=0; i < n; i++) {
    for( j = n; j > i; j-- ) {
      if ( m[j-1] > m[j]) {
          b = m[j-1];
          m[j-1] = m[j];
          m[j] = b;
    }
   }
  }
 }
//-сортировка пузырьком по убиванию------------------------------------------
void SortU(int n)
 {
  int b, i, j;
  for (i = 0; i < n; i++) {
      for (j = 0; j < i; j++) {
          if ( mc[j+1] > mc[j]) {
              b = mc[j+1];
              mc [j+1] = mc[j];
              mc[j] = b;
          }
      }
  }
 }
//-вывод массивов------------------------------------------------------------
 void Out(int n)
 {
     cout << "Массив 1\tПростые числа";
     for (int i = 0; i < n; i++) {
          cout << m[i] << "\t" << mc[i];}
 }
//---------------------------------------------------------------------------
int main()
 {
  ZapMas(50);
  CopyPCh(50);
  SortV(50);
  SortU(50);
  Out(50);
  return 0;
 }
//---------------------------------------------------------------------------
После отладке(Run Without Debugging) выдает следующее:

При запуске(Run):

нажимаю Break подсвечивает всю строчку темно красным:

return( x * factorial (x - 1));

если Continue так же подсвечивает темно красным и говорит:
Миниатюры
Ошибки после компиляции   Ошибки после компиляции   Ошибки после компиляции  

Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.10.2009, 22:03     Ошибки после компиляции
Посмотрите здесь:

Ошибки в компиляции C++
Ошибки при компиляции C++
C++ Ошибки компиляции
ошибки компиляции C++
C++ Непонятные ошибки компиляции!!!!
Ошибки при компиляции C++
C++ Ошибки компиляции
C++ Ошибки при компиляции
Непонятные ошибки компиляции C++
Ошибки при компиляции C++
C++ Ошибки при компиляции
Непонятные ошибки компиляции C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
.::.DIMA.::.
142 / 142 / 4
Регистрация: 26.10.2008
Сообщений: 782
07.10.2009, 22:33     Ошибки после компиляции #2
Цитата Сообщение от DDT Посмотреть сообщение
long int factorial(int x)//функция находит факториал рекурсивным методом
{
return(x * factorial (x - 1));
}
А где условие прекращение рекурсии?
С какого-то момента программе нужно будет вычислить факториал от отрицательного числа, вот тут-то и должно быть исключение.
M128K145
Эксперт C++
 Аватар для M128K145
8276 / 3495 / 142
Регистрация: 03.07.2009
Сообщений: 10,707
07.10.2009, 22:42     Ошибки после компиляции #3
перепиши
C++
1
2
3
4
long int factorial(int x)//функция находит факториал рекурсивным методом
 {
        return (x > 2)? (x * factorial (x - 1)) : 1;
 }
BCB 6.0 не ругается и все нормально отрабатывает
Миниатюры
Ошибки после компиляции  
DDT
Сообщений: n/a
07.10.2009, 23:01     Ошибки после компиляции #4
Цитата Сообщение от M128K145 Посмотреть сообщение
перепиши
C++
1
2
3
4
long int factorial(int x)//функция находит факториал рекурсивным методом
 {
        return (x > 2)? (x * factorial (x - 1)) : 1;
 }
BCB 6.0 не ругается и все нормально отрабатывает
Спасибо все работает! Еще один вопрос по поводу этой строчки : 1 это что озночает?
M128K145
Эксперт C++
 Аватар для M128K145
8276 / 3495 / 142
Регистрация: 03.07.2009
Сообщений: 10,707
07.10.2009, 23:15     Ошибки после компиляции #5
C++
1
(условие) ? true : false;
Yandex
Объявления
07.10.2009, 23:15     Ошибки после компиляции
Ответ Создать тему
Опции темы

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