0 / 0 / 0
Регистрация: 20.12.2009
Сообщений: 13
1

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

08.01.2010, 21:04. Показов 2292. Ответов 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
0 / 0 / 0
Регистрация: 20.12.2009
Сообщений: 13
10.01.2010, 20:18  [ТС] 21
Author24 — интернет-сервис помощи студентам
Хээээээлп, у меня снова проблемы

Описать функцию, вычисляющую значение выражения у=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 << " ";
  }
}
0
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
12454 / 7479 / 1752
Регистрация: 25.07.2009
Сообщений: 13,755
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;
}
1
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();
 
 
  }
 
}
В файл сохраняется только последняя пара значений... не могу понять почему
0
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
12454 / 7479 / 1752
Регистрация: 25.07.2009
Сообщений: 13,755
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;
}
0
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;
}
Объясните вот это кто-нибудь, пожалуйста.
0
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. Это пример того, как НЕ стоит писать функции, а код должен быть как можно более простым.
1
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
12454 / 7479 / 1752
Регистрация: 25.07.2009
Сообщений: 13,755
13.01.2010, 02:12 27
Цитата Сообщение от Mulat Посмотреть сообщение
p.s. Это пример того, как НЕ стоит писать функции, а код должен быть как можно более простым.
Ну Вы-то в нём как-то разобрались? И ведь не то, чтоб сложно было, правда? А простой код на бейсике пишут...
Мне вот за такую краткость С и нравится. На первый взгляд жутко, а как присмотришься - логично всё и просто. Зачем размазывать на два экрана то, что в две строки помещается? Чтоб кто-нибудь читающий голову не напрягал? Пусть Данцову читает - там точно не прийдётся!
0
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;
}
0
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
12454 / 7479 / 1752
Регистрация: 25.07.2009
Сообщений: 13,755
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?
0
182 / 183 / 55
Регистрация: 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;
}
0
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
12454 / 7479 / 1752
Регистрация: 25.07.2009
Сообщений: 13,755
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; 
}
Вот об это действительно голову сломал. И по-моему оно зациклится...
0
182 / 183 / 55
Регистрация: 08.04.2009
Сообщений: 1,309
13.01.2010, 14:01 32
Цитата Сообщение от easybudda Посмотреть сообщение
Вот об это действительно голову сломал. И по-моему оно зациклится...
Вполне возможно
Но главное ф-ция ищет минимальный элемент
0
13.01.2010, 14:01
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
13.01.2010, 14:01
Помогаю со студенческими работами здесь

Прога не компилится!
Выдаёт такие ошибки: 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); ...

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


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

Или воспользуйтесь поиском по форуму:
32
Ответ Создать тему
Опции темы

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