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

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

Восстановить пароль Регистрация
 
 
Рейтинг: Рейтинг темы: голосов - 11, средняя оценка - 5.00
Soledan
0 / 0 / 0
Регистрация: 20.12.2009
Сообщений: 13
08.01.2010, 21:04     Не компилится! #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
#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;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.01.2010, 21:04     Не компилится!
Посмотрите здесь:

C++ Ну никак не компилится.
Переменная в register, операция >>, во что компилится? C++
Не компилится файл. C++
C++ не компилится с++
C++ Компилится на одной машине
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Soledan
0 / 0 / 0
Регистрация: 20.12.2009
Сообщений: 13
10.01.2010, 20:18  [ТС]     Не компилится! #21
Хээээээлп, у меня снова проблемы

Описать функцию, вычисляющую значение выражения у=3х^3+2х^2+х, отобразить на экране таблицу значений данного выражения. Тема задачи- Работа с файлами. То есть нужно в файл данные занести конечные, я так понимаю... а я вообще в этом дуб дубом. И expression syntax меня замучал, не пускает меня дальше.

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 <math.h>
#include <conio.h>
#include <iostream.h>
#include <vcl.h>
#pragma hdrstop
 
//---------------------------------------------------------------------------
 
#pragma argsused
int Value(int x, int y);
int main(int argc, char* argv[])
{
Value(int x, int y);
cout << y << " ";
getch();
return 0;
}
 
int Value(int x, int y)
{
  for (x = -10; x< 10; x++)
  {
  y = (3*x)^3 + (2*x)^2 + x;
   }
  return y;
 }
Это я пытаюсь хотя бы вычислить что-нибудь.

Добавлено через 18 минут
Вычислил, как создать файл-таблицу с результатами?

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 <math.h>
#include <conio.h>
#include <iostream.h>
#include <vcl.h>
#pragma hdrstop
 
//---------------------------------------------------------------------------
 
#pragma argsused
int Value(int x, int y);
int main(int argc, char* argv[])
{
int x,y;
Value(x,y);
getch();
return 0;
}
 
int Value(int x, int y)
{
  for (x = -10; x<= 10; x++)
  {
  y = (3*x)*(3*x)*(3*x) + (2*x)*(2*x) + x;
  cout << y << " ";
  }
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9371 / 5421 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
10.01.2010, 20:27     Не компилится! #22
Ну так действительно что-нибудь и вычислите
1. Сначала идут действия внутри скобок
2. потом экспоненты/степени
3. потом умножение и деление в порядке следования слева направо
4. потом сложение и вычитание в порядке следования слева направо
C
1
2
3
4
5
6
7
8
9
10
11
12
#include <stdio.h>
 
int val(int x){
    return 3*x*x*x + 2*x*x + x;
}
 
int main(void){
    int x;
    for ( x = -10; x < 11; ++x )
        printf("x = %d\ty = %d\n", x, val(x));
    return 0;
}
Soledan
0 / 0 / 0
Регистрация: 20.12.2009
Сообщений: 13
10.01.2010, 21:36  [ТС]     Не компилится! #23
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
//---------------------------------------------------------------------------
#include <math.h>
#include <stdlib.h>
#include <fstream.h>
#include <conio.h>
#include <stdio.h>
#include <iostream.h>
#include <vcl.h>
#pragma hdrstop
 
//---------------------------------------------------------------------------
 
#pragma argsused
int Value(int x, int y);
int main(int argc, char* argv[])
{
int x,y;
Value(x,y);
 
getch();
return 0;
}
 
int Value(int x, int y)
{
 
  for (x = -10; x<= 10; x++)
  {
  y = (3*x)*(3*x)*(3*x) + (2*x)*(2*x) + x;
  cout << x << "   " << y << '\n';
 }
  for (x = -10; x<=10; x++)
  {
  ofstream outfile ("1.txt");
outfile << x << "   " << y << '\n';
 
outfile.close();
 
 
  }
 
}
В файл сохраняется только последняя пара значений... не могу понять почему
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9371 / 5421 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
10.01.2010, 22:01     Не компилится! #24
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
#include <iostream>
#include <fstream>
#include <iomanip>
 
using namespace std;
 
int val(int x){
    return 3*x*x*x + 2*x*x + x;
}
 
int main(){
    int i;
    ofstream ofs("xy.txt");
    if ( !ofs.is_open() ){
        cerr << "Can't open output file!" << endl;
        return 1;
    }
    for ( i = -10; i < 11; ++i )
        ofs << setw(3) << i << '\t' << setw(5) << val(i) << endl;
    if ( ofs.bad() ){
        cerr << "Can't write to file!" << endl;
        return 1;
    }
    ofs.close();
    return 0;
}
Soledan
0 / 0 / 0
Регистрация: 20.12.2009
Сообщений: 13
13.01.2010, 01:46  [ТС]     Не компилится! #25
Цитата Сообщение от easybudda Посмотреть сообщение
"Круто" - это когда рекурсивная функция сама себя вызывает!
C
1
2
3
4
5
int minVal(int *arr, int cnt){
    if ( cnt-- > 1 )
        return ( *arr > *(arr + cnt) ) ? minVal(++arr, cnt) : minVal(arr, cnt); 
    return *arr;
}
Объясните вот это кто-нибудь, пожалуйста.
Mulat
7 / 7 / 0
Регистрация: 09.01.2009
Сообщений: 41
13.01.2010, 02:06     Не компилится! #26
Функция minVal получает массив arr и его величину cnt.
Если cnt=1, возвращает arr[0]
а если cnt>1, сравнивает arr[0] с arr[cnt-1] и вызывает сама себя рекурсивно либо с подмассивом arr[0]...arr[cnt-2] , либо с arr[1]...arr[cnt-1], в зависимости от того, что больше: arr[0] или arr[cnt-1].
p.s. Это пример того, как НЕ стоит писать функции, а код должен быть как можно более простым.
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9371 / 5421 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
13.01.2010, 02:12     Не компилится! #27
Цитата Сообщение от Mulat Посмотреть сообщение
p.s. Это пример того, как НЕ стоит писать функции, а код должен быть как можно более простым.
Ну Вы-то в нём как-то разобрались? И ведь не то, чтоб сложно было, правда? А простой код на бейсике пишут...
Мне вот за такую краткость С и нравится. На первый взгляд жутко, а как присмотришься - логично всё и просто. Зачем размазывать на два экрана то, что в две строки помещается? Чтоб кто-нибудь читающий голову не напрягал? Пусть Данцову читает - там точно не прийдётся!
Soledan
0 / 0 / 0
Регистрация: 20.12.2009
Сообщений: 13
13.01.2010, 06:37  [ТС]     Не компилится! #28
Срочно нужен совет!!! В чём ошибка? Нужна рекурсия.

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
#include <math.h>
#include <stdlib.h>
#include <fstream.h>
#include <stdio.h>
#include <iostream.h>
#include <vcl.h>
#include <conio.h>
#pragma hdrstop
//--------------------------------------------------------------------------
#pragma argsused
using namespace std;
const int N = 20;
unsigned long  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();
}
 
unsigned long  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 = Minimum(i);
  }
  return Min;
}
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9371 / 5421 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
13.01.2010, 09:03     Не компилится! #29
Цитата Сообщение от Soledan Посмотреть сообщение
C++
1
2
3
4
unsigned long Minimum(int A[N],int i,int Min) { 
...
   Min = Minimum(i);
...
функция объявлена с тремя параметрами, а вызывается с одним. Кстати, почему unsigned long?
vet
 Аватар для vet
175 / 175 / 13
Регистрация: 08.04.2009
Сообщений: 1,309
13.01.2010, 09:32     Не компилится! #30
C
1
2
const int N = 20;
int Minimum(int A[N]);
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
  cout<<"\nMinimum: "<<Minimum(A);
  getch();
  getch();
}
 
int  Minimum(int A[N])
{
     int Min,i;
  for (i=0;i<N;i++)
  {
  if (i==0) Min=A[i];
    if (A[i]< Min)
      Min = Minimum(A);
  }
  return Min;
}
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9371 / 5421 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
13.01.2010, 10:49     Не компилится! #31
Цитата Сообщение от vet Посмотреть сообщение
C
1
2
3
4
5
6
7
8
9
10
int Minimum(int A[N]) { 
  int Min,i; 
  for (i=0;i<N;i++) { 
    if (i==0) 
      Min=A[i]; 
    if (A[i]< Min) 
      Min = Minimum(A); 
  } 
  return Min; 
}
Вот об это действительно голову сломал. И по-моему оно зациклится...
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
13.01.2010, 14:01     Не компилится!
Еще ссылки по теме:

Компилится синтаксически неверный код C++
srand не компилится C++
Не компилится *.cpp C++

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

Или воспользуйтесь поиском по форуму:
vet
 Аватар для vet
175 / 175 / 13
Регистрация: 08.04.2009
Сообщений: 1,309
13.01.2010, 14:01     Не компилится! #32
Цитата Сообщение от easybudda Посмотреть сообщение
Вот об это действительно голову сломал. И по-моему оно зациклится...
Вполне возможно
Но главное ф-ция ищет минимальный элемент
Yandex
Объявления
13.01.2010, 14:01     Не компилится!
Ответ Создать тему
Опции темы

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