Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
0 / 0 / 0
Регистрация: 20.12.2009
Сообщений: 13
1

Не компилится!

08.01.2010, 21:04. Показов 2299. Ответов 31
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте. Подскажите ошибки пожалуйста.

Задание: Написать рекурсивную функцию, которая принимает массив и размер массива, а возвращает наименьший элемент массива.

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
#include <vcl.h>
#include <iostream.h>
#include <conio.h>
#include <stdlib.h>
#include <stdio.h>
#pragma hdrstop
//--------------------------------------------------------------------------
#pragma argsused
int Minimum(int A[20]);
int i, Min, A[20];
void main()
{
 
randomize();
for (i = 0; i < 20; i++)
{
A[i] = random(100)-50;
cout << A[i] << " ";
}
Minimum(int A[20]);
getch();
}
int Minimum(int A[20])
{
int i;
int Min = A[0];
for (i = 0; i < 20; i++)
{
if (A[i]< Min) {
Min = A[i];
else
Min = Minimum(int A[0]);
}
}
cout << "\n" << Min;
return Min;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
08.01.2010, 21:04
Ответы с готовыми решениями:

не компилится с++
Ребят,я чего-то туплю... #include &lt;iostream&gt; #include &lt;conio.h&gt; #include &lt;math.h&gt; using...

Ну никак не компилится.
Начинаю изучать С++, никак не компилится: -------------------------------------------- #include ...

Не компилится *.cpp
Создал заголовочный файл *.h , он описывает интерфейс класса. Создал файл исходного кода *.срр , он...

srand не компилится
void Client::InitializeRandSessionKey() { srand(time(NULL)); randSessionKey=rand()%100; } ...

31
425 / 229 / 87
Регистрация: 25.03.2009
Сообщений: 744
08.01.2010, 21:14 2
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
 
int func(int *a, int left, int right)
{
    if (left == right) return a[left];
    int sred = (left+right)/2;
    int min_1 = func(a,left,sred);
    int min_2 = func(a,sred+1,right);
    if (min_1 < min_2) return min_1;
    else
        return min_2;
}
 
int main()
{
    int arr[] = {-6,1,2,3,4,5,0,3,4,5,10,20,-5};
    std::cout << func(arr,0,sizeof(arr)/sizeof(*arr)-1);
    system("pause");
    return 0;
}
не компилил, проверь.
1
135 / 69 / 12
Регистрация: 10.10.2009
Сообщений: 187
08.01.2010, 21:19 3
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
int Minimum(int *a,int n);
 
void main()
 {
  clrscr();
 
  int n,i;cout<<"Enter size :";cin>>n;
  int *a;
  a=(int *)calloc(n,sizeof(int));
 
  randomize();
  for (i = 0; i < n; i++)
   {
    a[i] = random(100)-50;
    cout << a[i] << " ";
   }
  cout<<"\min element:"<<Minimum(a,n);
  getch();
}
 
int Minimum(int *a,int n)
 {
  int i;
  int Min = a[0];
  for (i = 0; i < n; i++)
   {
    if (a[i]< Min)
     Min = a[i];
   }  
  return Min;
 }
1
0 / 0 / 0
Регистрация: 20.12.2009
Сообщений: 13
08.01.2010, 21:21  [ТС] 4
E2268, насколько я понял, он не опознаёт функцию "system". И... какая функция там собственно рекурсивная? Я просто далековат от программирования, только азы ещё освоил.
0
Быдлокодер
512 / 298 / 85
Регистрация: 22.11.2009
Сообщений: 892
08.01.2010, 21:22 5
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
#include <vcl.h>
#include <iostream.h>
#include <conio.h>
#include <stdlib.h>
#include <stdio.h>
#pragma hdrstop
//--------------------------------------------------------------------------
#pragma argsused
#define N 20
using namespace std;
  int Minimum(int A[N],int i,int Min);
void main()
{
int i, Min, A[N];
  randomize();
  for (i=0;i<N;i++)
  {
      A[i]=random(100)-50;
      cout<<A[i]<<" ";
  }
  Minimum(A,i,Min);
}
 
int Minimum(int A[N],int i,int Min)
{
  for (i=0;i<N;i++)
  {
  if (i==0) Min=A[i];
    if (A[i]< Min)
      Min = A[i];
  }
  cout<<"\n\n"<<Min;
  getch();
  return Min;
}
1
0 / 0 / 0
Регистрация: 20.12.2009
Сообщений: 13
08.01.2010, 21:27  [ТС] 6
Ой, спасибо вам огромное. 2 вопроса: Как поточнее сказать определение рекурсии и где она в моём случае? И преподаватель ругает за использование глобальных переменных и дефайнов. Знаю, что можно использовать числовые переменные в конкретной функции, но как задать ей константный тип?
0
135 / 69 / 12
Регистрация: 10.10.2009
Сообщений: 187
08.01.2010, 21:43 7
рекурсия - вызов функции решения в вашем случае ( из моей програмы ) :
cout<<"\min element:"<<Minimum(a,n);
1
0 / 0 / 0
Регистрация: 20.12.2009
Сообщений: 13
08.01.2010, 21:48  [ТС] 8
Цитата Сообщение от Radjuk Посмотреть сообщение
рекурсия - вызов функции решения в вашем случае ( из моей програмы ) :
Понятно, спасибо.
0
Быдлокодер
512 / 298 / 85
Регистрация: 22.11.2009
Сообщений: 892
08.01.2010, 21:55 9
А, рекурсия?
Тогда мой код немного преобразится
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
#include <iostream.h>
#include <conio.h>
#include <stdlib.h>
#include <stdio.h>
#define N 20
using namespace std;
  int Minimum(int A[N],int i,int Min);
void main()
{
int i, Min, A[N];
  randomize();
  for (i=0;i<N;i++)
  {
      A[i]=random(100)-50;
      cout<<A[i]<<" ";
  }
  cout<<"\nMinimum: "<<Minimum(A,i,Min);
  getch();
}
 
int Minimum(int A[N],int i,int Min)
{
  for (i=0;i<N;i++)
  {
  if (i==0) Min=A[i];
    if (A[i]< Min)
      Min = A[i];
  }
  return Min;
}
А define можно с чистой душой менять на const int N = 20, отвечая на вышезаданный вопрос
1
0 / 0 / 0
Регистрация: 20.12.2009
Сообщений: 13
08.01.2010, 21:57  [ТС] 10
Цитата Сообщение от Darky Посмотреть сообщение
А, рекурсия?
Тогда мой код немного преобразится
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
#include <iostream.h>
#include <conio.h>
#include <stdlib.h>
#include <stdio.h>
#define N 20
using namespace std;
  int Minimum(int A[N],int i,int Min);
void main()
{
int i, Min, A[N];
  randomize();
  for (i=0;i<N;i++)
  {
      A[i]=random(100)-50;
      cout<<A[i]<<" ";
  }
  cout<<"\nMinimum: "<<Minimum(A,i,Min);
  getch();
}
 
int Minimum(int A[N],int i,int Min)
{
  for (i=0;i<N;i++)
  {
  if (i==0) Min=A[i];
    if (A[i]< Min)
      Min = A[i];
  }
  return Min;
}
А define можно с чистой душой менять на const int N = 20, отвечая на вышезаданный вопрос
Вот, да, теперь всё круто, спасибо =)
0
135 / 69 / 12
Регистрация: 10.10.2009
Сообщений: 187
08.01.2010, 21:57 11
Darky, а можно вопрос?

а для чего вы еще и
int Minimum(int A[N],int i,int Min);
int i вносите в рекурсию?
0
Быдлокодер
512 / 298 / 85
Регистрация: 22.11.2009
Сообщений: 892
08.01.2010, 21:59 12
Radjuk, Банальная привычка. Вне сомнений, это можно уничтожить.
0
135 / 69 / 12
Регистрация: 10.10.2009
Сообщений: 187
08.01.2010, 22:00 13
я уже потом увидел что бы не обявлять переменую в функцие
0
0 / 0 / 0
Регистрация: 20.12.2009
Сообщений: 13
08.01.2010, 22:08  [ТС] 14
Пока вы здесь, может ещё задачку посмотрите? Вроде всё правильно надумано, но написано, говорят, не так.
Нужно найти периметры треугольников ABC и ACD. Переменные вещественные.

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
//---------------------------------------------------------------------------
#include <math.h>
#include <conio.h>
#include <iostream.h>
#include <vcl.h>
#pragma hdrstop
 
//---------------------------------------------------------------------------
 
#pragma argsused
float Perim(Ax, Ay, Bx, By, Cx, Cy, Dx, Dy)
int main(int argc, char* argv[])
{
float Ax, Ay, Bx, By, Cx, Cy, Dx, Dy, PABC, PACD;
randomize();
Ax= random(20)-10;
cout << Ax << " ";
Ay= random(20)-10;
cout << Ay << " ";
Bx= random(20)-10;
cout << Bx << " ";
By= random(20)-10;
cout << By << " ";
Cx= random(20)-10;
cout << Cx << " ";
Cy= random(20)-10;
cout << Cy << " ";
Dx= random(20)-10;
cout << Dx << " ";
Dy= random(20)-10;
cout << Dy << " ";
Perim();
getch();
return 0;
}
 
 float Perim(Ax, Ay, Bx, By, Cx, Cy, Dx, Dy)
{
 PABC = sqrt(sqr(Bx-Ax) + sqr(By-Ay)) + sqrt(sqr(Cx-Bx) + sqr(Cy-By)) +
 sqrt (sqr(Cx-Ax) + sqr(Cy-Ay));
 PACD = sqrt(sqr(Cx-Ax) + sqr(Cy-Ay)) + sqrt(sqr(Dx-Cx) + sqr(Dy-Cy)) +
 sqrt (sqr(Dx-Ax) + sqr(Dy-Ay));
 cout << "\n" << PABC;
 cout << "\n" << PACD;
}
//---------------------------------------------------------------------------
Знаю, что sqr надо на ^2 вроде как менять. Больше что-то ничего не знаю.
0
135 / 69 / 12
Регистрация: 10.10.2009
Сообщений: 187
08.01.2010, 22:30 15
ну так вносите даные в функцию
1
Быдлокодер
512 / 298 / 85
Регистрация: 22.11.2009
Сообщений: 892
08.01.2010, 22:32 16
Зачем столько переменных, о ужас.
32 строка
C++
1
Perim(Ax, Ay, Bx, By, Cx, Cy, Dx, Dy);
1
0 / 0 / 0
Регистрация: 20.12.2009
Сообщений: 13
08.01.2010, 22:35  [ТС] 17
Radjuk,
Darky,

Ох, ё-моё, точно)... а переменные для расчёта по координатам двумерной системы координат.
0
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
12458 / 7482 / 1753
Регистрация: 25.07.2009
Сообщений: 13,762
08.01.2010, 22:35 18
Цитата Сообщение от Soledan Посмотреть сообщение
Вот, да, теперь всё круто
"Круто" - это когда рекурсивная функция сама себя вызывает!
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
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
 
/*
    Написать рекурсивную функцию, которая принимает массив и размер массива, 
    а возвращает наименьший элемент массива.
*/
int minVal(int *arr, int cnt){
    if ( cnt-- > 1 )
        return ( *arr > *(arr + cnt) ) ? minVal(++arr, cnt) : minVal(arr, cnt); 
    return *arr;
}
 
#define ARRSIZE 10
int main(void){
    int arr[ARRSIZE], i;
    
    srand(time(NULL));
    for ( i = 0; i < ARRSIZE; ++i ){
        arr[i] = rand() % 10;
        printf("%d ", arr[i]);
    }
    printf("\nMin. value = %d", minVal(arr, ARRSIZE));
    
    exit(0);
}
1
135 / 69 / 12
Регистрация: 10.10.2009
Сообщений: 187
08.01.2010, 22:37 19
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
float Perim(float Ax, float Ay, float Bx, float By,float Cx,float Cy,float Dx,float Dy);
int main(int argc, char* argv[])
{
float Ax, Ay, Bx, By, Cx, Cy, Dx, Dy, PABC, PACD;
randomize();
Ax= random(20)-10;
cout << Ax << " ";
Ay= random(20)-10;
cout << Ay << " ";
Bx= random(20)-10;
cout << Bx << " ";
By= random(20)-10;
cout << By << " ";
Cx= random(20)-10;
cout << Cx << " ";
Cy= random(20)-10;
cout << Cy << " ";
Dx= random(20)-10;
cout << Dx << " ";
Dy= random(20)-10;
cout << Dy << " ";
Perim(Ax,Ay,Bx,By,Cx,Cy,Dx,Dy);
getch();
return 0;
}
 
 float Perim(float Ax, float Ay, float Bx, float By,float Cx,float Cy,float Dx,float Dy)
 
{  float PABC;
 PABC = sqrt((Bx-Ax)*(Bx-Ax) + sqr(By-Ay)) + sqrt(sqr(Cx-Bx) + sqr(Cy-By)) +
 sqrt (sqr(Cx-Ax) + sqr(Cy-Ay));
 PACD = sqrt(sqr(Cx-Ax) + sqr(Cy-Ay)) + sqrt(sqr(Dx-Cx) + sqr(Dy-Cy)) +
 sqrt (sqr(Dx-Ax) + sqr(Dy-Ay));
 cout << "\n" << PABC;
 cout << "\n" << PACD;
}
Добавлено через 46 секунд
там еще подправите Sqr и с перемеными посмотрите)
1
0 / 0 / 0
Регистрация: 20.12.2009
Сообщений: 13
08.01.2010, 22:51  [ТС] 20
easybudda, Ой, это как-то всё непонятно написано Оо... но работает, спасибо. Разбираться будем.

Radjuk, Всё, исправил, работает. Спасибо =)
0
08.01.2010, 22:51
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
08.01.2010, 22:51
Помогаю со студенческими работами здесь

Прога не компилится!
Выдаёт такие ошибки: error C4430: отсутствует спецификатор типа - предполагается int. Примечание....

Не компилится файл.
http://www.piter.com/bugs/5-469-00893-2/files.rar Вот исходники. 18 задание. Написано под дос....

Не компилится из-за лямбды
void Chair::wait_invite(const int &amp;id_client) { unique_lock &lt;mutex&gt; lk(mx_chair); ...

Не компилится код
Короче суть задачи такая: Сделать класс матрицы который будет хранить не нулевые элементы и методы...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru