Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
lj23lj
1 / 1 / 0
Регистрация: 15.11.2011
Сообщений: 34
#1

Реализовать код данной функции, но через рекурсию - C++

21.04.2013, 22:06. Просмотров 1167. Ответов 31
Метки нет (Все метки)

Добрый вечер. Прошу помочь реализовать функцию Mult с помощью рекурсии. Там формируется матрица произведений. Вот сделть, чтобы она формировалась рекурсивно. Эта функция находится в function.cpp. Заранее большое спасибо за ответы и советы)

Собственно вот задание Имеется 2*N чисел. Известно, что их можно разбить на пары таким образом, что произведения чисел в пара:х равны. Сделать разбиение, если числа:
а) натуральные;
б) целые.
Решение: В качестве входных данных будет массив, записанный в файл. Количество элементов в нем должно быть четное, для того, чтобы можно было сформировать пары чисел. Задача будет решена путем построения двумерной матрицы (n*n), где n – количество элементов в исходном массиве. Каждый элемент такой матрицы будет содержать произведение элементов из исходного массива, рассматриваемого относительно индексов в двумерном массиве. Например, в двумерной матрице элемент с индексами (1,2) будет являться произведением элементов из исходного массива с индексами (1) и (2) соответственно. Если исходный массив можно разбить на пары чисел с одинаковым произведением между ними, то любая строка двумерной матрицы будет содержать одно повторяющееся значение. Цель программы – построить двумерную матрицу и отыскать такое произведение. Отыскав это произведение, будет несложно построить пары чисел с одинаковым произведением. Замечание: исходные пары будут содержать числа в единственном экземпляре, или другими словами, повторяющиеся пары не будут учитываться. Это будет продемонстрировано в контрольном примере ниже.
Программа написана таким образом, что она учитывает сразу 2 варианта задания, когда числа натуральные и когда числа целые.
Я не прикрепил файл с входными данными и заголовочный файл.
файл Function.cpp
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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
#include <iostream>
#include <math.h>
#include "Function.h"
using namespace std;
 
int StrToInt(char * str) 
{
    int len=strlen(str);
    int temp=0;
    //переменная для формирования числа
    int i;
    if (str[0]!='-')
        i=0;
    //условие на проверку какое число: отрицательное или положительное
    else
        i=1;
    for (i;i<len;i++)
    {
        switch (str[i])
        {
            case '1':
                temp+=1*pow(10.0,double(len-i-1));
                break;
            case '2':
                temp+=2*pow(10.0,double(len-i-1));
                break;
            case '3':
                temp+=3*pow(10.0,double(len-i-1));
                break;
            case '4':
                temp+=4*pow(10.0,double(len-i-1));
                break;
            case '5':
                temp+=5*pow(10.0,double(len-i-1));
                break;
            case '6':
                temp+=6*pow(10.0,double(len-i-1));
                break;
            case '7':
                temp+=7*pow(10.0,double(len-i-1));
                break;
            case '8':
                temp+=8*pow(10.0,double(len-i-1));
                break;
            case '9':
                temp+=9*pow(10.0,double(len-i-1));
                break;
            case '0':
                temp+=0*pow(10.0,double(len-i-1));
                break;
        }
    }
    if (str[0]=='-')
        temp=-temp;
    //если число отрицательное
    return temp;
}
 
void AnalizingStr(char * str, int * arr1, int n)
{
    int i=0;
    char * tmpstr = new char [10];
    //временная строка для каждого числа из файла
    int j=0;
    int k=0;
    while (str[i]!='\0')
    {
        if (str[i]!=' ')
        {
            tmpstr[j]=str[i];
            j++;
            if ((str[i+1]==' ') || (str[i+1]=='\0'))
            {
                tmpstr[j]='\0';
                j=0;
                arr1[k]=StrToInt(tmpstr);
                //вызов функции перевода числа из символьного типа в числовой
                k++;
            }
        }
        i++;
    }
    delete [] tmpstr;
}
 
int Mult(int * arr1, int * arr2, int n, int & m)
{
    m=0;
    //количество элементов в массиве, содержащий пары
    int ** indexes = new int * [n];
    //двумерная матрица для построения произведений различных пар
    int i,j,k;
    //счетчики
    for (i=0;i<n;i++)
        indexes[i]=new int [n];
    for (i=0;i<n;i++)
    {
        for (j=0;j<n;j++)
        {
            indexes[i][j]=arr1[i]*arr1[j];
            //формирование произведений чисел в каждой паре
        }
    }
    int mult;
    //переменная для поиска одинакового произведения в парах
    int count;
    //переменная, отвечающая за количество встретившихся одинаковых произведений в строках двумерной матирцы
    int globalflag=0;
    //флаг, отвечающий за то, были ли построены все пары из входного массива
    int flag;
    //локальный флаг для исключения повторений в результирующих парах
    for (i=1;i<n;i++)
    {
        count=0;
        mult=indexes[0][i];
        for (j=1;j<n;j++)
        {
            for (k=0;k<n;k++)
            {
                if ((j!=k) && (indexes[j][k]==mult))
                {
                    //если в строке найдено искомое произведение
                    count++;
                    break;
                }
            }
        }
        if (count==(n-1))
        {
            //если искомое произведение есть во всех строках двумерной матрицы
            globalflag=1;
            for (j=0;j<n;j++)
            {
                for (k=0;k<n;k++)
                {
                    //циклы по двумерной матрице для формирования пар
                    if (indexes[j][k]==mult)
                    {
                        //если в строке найдено искомое произведение
                        flag=0;
                        for (int h=0;h<m;h+=2)
                        {
                            //проверка на иключение повторения пар
                            if ((arr2[h]==arr1[j]) && (arr2[h+1]==arr1[k]))
                                flag=1;
                            if ((arr2[h]==arr1[k]) && (arr2[h+1]==arr1[j]))
                                flag=1;
                        }
                        if (flag==0)
                        {
                            //если пара чисел не встречается в уже составленных парах, то записываем ее в результирующий массив
                            arr2[m++]=arr1[j];
                            arr2[m++]=arr1[k];
                        }
                    }
                }
            }
        }
    }
    for (i=0;i<n;i++)
        delete [] indexes[i];
    delete [] indexes;
    if (globalflag==1)
        return 1;   //если пары были построены
    else
        return 0;   //если пары не были построены
}
файл main.cpp
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
87
#include <iostream>
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include "Function.h"
using namespace std;
 
void main(int argc, char* argv[])
{
setlocale(0, "rus");
    char * filestr = new char [100];
    //строка для ввода адреса к файлу
    cout<<"Укажите адрес к файлу (с расширением):"<<endl;
    cin>>filestr;
    FILE * fr = fopen(filestr,"r");
 
    /*FILE * fr;
    if(argc!=2)//проверка аргументов на наличе
    {
        cout<<"Ошибка!"<<endl;
        exit(-1);
    }
    fr=fopen(argv[1],"r");//открываем файл на чтение, r-значит на чтение
    if(!fr) exit(-1);//проверка есть ли файл*/
 
    if (!fr)
    {
        //если файл не был найден
        delete [] filestr;
        cout<<"Файл не найден. Программа закрывается!"<<endl;
        system("pause");
        return;
    }
    delete [] filestr;
    cout<<endl;
    int count=0;
    //переменная для количества чисел в файле
    int countch=0;
    //переменная для количества символов в файле
    char ch;
    while ((ch=fgetc(fr))!='\n')
    {
        countch++;
        if (ch==' ')
            count++;
    }
    if ((count+1)%2!=0)
    {
        //если количество чисел в файле не четное
        fclose(fr);
        cout<<"Количество чисел в не четное! Пожалуйста исправьте входные данные и перезапустите программу."<<endl;
        return;
    }
    char * str = new char [countch+1];
    int * arr1 = new int [count+1];
    int * arr2 = new int [count+1];
    fseek(fr,0,SEEK_SET);
    //смещаем указатель на файл
    fgets(str,countch+1,fr);
    //считываем первую строку из файла с числами
    AnalizingStr(str,arr1,count+1);
    //вызов функции для анализа и перевода чисел из символьного типа в числовой
    int check;
    //переменная для проверки, построены ли пары чисел
    int m;
    //количество элементов в результирующем массиве, содержащем пары
    check=Mult(arr1,arr2,count+1,m);
    cout<<"Входной массив:"<<endl;
    for (int i=0;i<count+1;i++)
        cout<<arr1[i]<<" ";
    //вывод исходного массива
    cout<<endl;
    if (check==1)
    {
        //вывод пар чисел
        cout<<"Пары:"<<endl;
        for (int i=0;i<m;i+=2)
            cout<<"("<<arr2[i]<<","<<arr2[i+1]<<")"<<endl;
    }
    else
        cout<<"Не удалось сформировать пары"<<endl;
    delete [] str;
    delete [] arr1;
    delete [] arr2;
    fclose(fr);
    getch();
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.04.2013, 22:06
Я подобрал для вас темы с готовыми решениями и ответами на вопрос Реализовать код данной функции, но через рекурсию (C++):

Реализовать вывод чисел в диапазоне от 10 до 25 через рекурсию - C++
Парни, нужно реализовать такое задание , но я сам нуб в этом а нужно очень. Помогите . Задание: Реализовать вывод чисел в диапазоне от...

Описание функции через рекурсию - C++
Описать логическую функцию ПОТОМОК(А,В), проверяющую, является ли человек с именем В потомком (ребенком, внуком, правнуком) человека с...

Программу, которая реализует решение задачи, через рекурсию, так и итеративной функции - C++
Я написал одну программу через рекурсию, как сделать вторую,через инеративную функцию? #include &quot;stdafx.h&quot; #include &lt;iostream&gt; ...

Реализовать данный код через функцию - C++
Делаю лабу...Все время сидел на Паскаль, а тут вдруг нужно на с++...Медленно, но уверенно, с синтаксисом разбираюсь. Сделал часть лабы... ...

Реализовать рекурсию - C++
Доброго времени суток! Никак не пойму как это сделать, хотябы направьте меня, что бы самому додумать Пусть в алгебраической записи...

Реализовать программу на рекурсию про шахматную доску - C++
Магараджа - шахматная фигура, сочетающая возможности ферзя и коня. Найти число способов расставить на доске с заданной размерностью NxN...

31
kravam
быдлокодер
1705 / 892 / 45
Регистрация: 04.06.2008
Сообщений: 5,524
22.04.2013, 00:30 #16
Второй раз.
В решении сказано:
"Если исходный массив можно разбить на пары чисел с одинаковым произведением между ними, то любая строка двумерной матрицы будет содержать одно повторяющееся значение."

Матрица у нас есть. Возьмём любую строку, например третью:
8 | 12 | 6 | 4 |2 |24

Где тут одно повторяющееся значение?
0
lj23lj
1 / 1 / 0
Регистрация: 15.11.2011
Сообщений: 34
22.04.2013, 01:25  [ТС] #17
Ну я и тогда понял ваше замечание.
Вот сейчас посчитал матрицу для предложенной вами цепочки: 16 24 12 8 4 48
получилась:
256 384 192 128 64 768
384 576 288 192 96 1152
192 288 144 96 48 576
128 192 96 64 32 384
64 96 48 32 16 192
768 1152 576 384 192 2304

Но да, как Вы заметили нет повторений там, где должны быть пары. Если посмотреть на цепочку, видно, что можно составить пары: 16,12 и 24,8 и 4,48. Что-то не так в алгоритме описано, видать...

Сейчас внимательно посмотрю ф-ию мульт. Как там идёт формирование этой матрицы.

Добавлено через 15 минут
kravam,
Посмотрел.
Но да, как Вы заметили нет повторений там, где должны быть пары. Если посмотреть на цепочку, видно, что можно составить пары: 16,12 и 24,8 и 4,48.
Далее, смотря по коду перемножаем числа в каждой строке матрицы. И тут то и должны получиться 2 одинаковых произведения. К примеру: перемножить индексы, соответствующие 16 и 12=49152, 24 и 8=49152. Всё, локально для строки это запомнилось. А потом после всего этого переходим к глобальному(вся матрица) и смотрим пары на повторы и тп
0
kravam
быдлокодер
1705 / 892 / 45
Регистрация: 04.06.2008
Сообщений: 5,524
22.04.2013, 10:41 #18
Давай попроще возьмём, я вчера таблицу написал, а ряд чисел забыл. Короче вот ряд чисел:
4 6 3 2 1 12

А вот таблица для этого ряда:
16 | 24 | 12 | 8 | 4 | 48
24 | 36 | 18 | 12 | 6 | 72
12 | 18 | 9 | 6 | 3 |36
8 | 12 | 6 | 4 |2 |24
4 | 6 | 3 | 2 |1 |12
48 | 72 | 36 | 24 |1 |144

++++++++++++++++++++++++++++++++++++++++

Я так понимаю, для этой таблицы должна быть какая-то закономерность. Но уж точно не:
"Если исходный массив можно разбить на пары чисел с одинаковым произведением между ними, то любая строка двумерной матрицы будет содержать одно повторяющееся значение."
Потому, что как я уже говорил, берём любую строку таблицы, например:
24 | 36 | 18 | 12 | 6 | 72

И не видим повторяющихся значений.
0
lj23lj
1 / 1 / 0
Регистрация: 15.11.2011
Сообщений: 34
22.04.2013, 12:40  [ТС] #19
kravam, Ну вот я и написал выше, что алгоритм будет другой похоже.

Допустим, взяли Вашу матрицу уже двумерную. И теперь повторяем то, что сделали уже на первом шаге, но для двумерной. Т.е для первой строки берём первое значение и перемножаем с остальными, для второй строки берём второе и перемножаем с остальными.
получилась вторая матрица:
256 384 192 128 64 768
864 1296 648 432 126 2596
108 162 81 54 27 324
32 48 24 16 8 96
4 6 3 2 1 12
6912 10368 5184 3456 144 20736

И,смотря по коду, теперь программа берёт в первой строке и перемножает по порядку циклом сначала первое со всеми, второе, третье и так далее. И запоминает значения, сравнивает их. Если есть равые произведения, то соответственно есть пара.
К примеру для строки 1) 256*192=49152, 384*128=49152, 64*768=49152
2) 864*648=559872, 1296*432=559872
3)108*81=8748, 162*54=8748,27*324=8748
4)32*24=768,48*16=768,8*96=768
И так далее. Т.е множители построчно соответствуют числам в первоначальной цепочке(входных данных) и из них строятся пары. и потом идёт проверка разных строк, чтоб не было повторяющихся пар.
0
kravam
быдлокодер
1705 / 892 / 45
Регистрация: 04.06.2008
Сообщений: 5,524
22.04.2013, 13:03 #20
Не, с марицей я пас.
Cлушай, а может вообще без матрицы обойтись? Например, сортирнём предлагаемый ряд чисел, имеем:
1 2 3 4 6 12

Всё, очевидно, если можно разбить этот ряд на пары, то одно число нужно брать сначала, а другое с конца, и никак иначе (хотя математики потребовали бы это доказать)

Тут как раз и рекурсия будет к месту. Щас оформим
0
lj23lj
1 / 1 / 0
Регистрация: 15.11.2011
Сообщений: 34
22.04.2013, 13:06  [ТС] #21
Кстати, да, идея хорошая!
0
kravam
быдлокодер
1705 / 892 / 45
Регистрация: 04.06.2008
Сообщений: 5,524
22.04.2013, 13:23 #22
Ну тогда вот
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
#include <stdio.h>
 
#define razmer 8
 
//Собсно сам массив
int array [razmer]= {1, 2, 3, 5, 6, 10, 15, 30}; 
 
//Это глобальная величина- произведение чисел
int pr; 
 
//параметр это индекс числа в массиве
//(в нашем случае индексы будут 0, 1, 2, 3) 
bool f (int index) {
 
 
 //В функции "сближаемся", идём от начала к концу,
 //если встретились- возвращаем true
 if (index==razmer/2)
  return true;
 else 
  if (array [index]* array [razmer- index- 1]!= pr) 
   return false;
  else 
   return (f(index+ 1));
}
 
//++++++++++++++++++++++++++++++++++++++++++++++++
 
int main()
{
    //НАйдём произведение чисел
    pr= array[0]* array[razmer- 1];
    
    printf ("%d\n", f (1));
    
    
    getchar ();
    return 0;
}
1
lj23lj
1 / 1 / 0
Регистрация: 15.11.2011
Сообщений: 34
22.04.2013, 15:33  [ТС] #23
kravam, Спасибо за код. Я тут пытался скомпилировать с этими исправлениями. Подправил исходный код, удалил лишнее, но в одном месте ошибка. Но я подозреваю, что исправив её, получится ещё море их.

файл: function.cpp

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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
#include <iostream>
#include <math.h>
#include "Function.h"
#define razmer 8
using namespace std;
 
 
int StrToInt(char * str) 
{
    int len=strlen(str);
    int temp=0;
    //переменная для формирования числа
    int i;
    if (str[0]!='-')
        i=0;
    //условие на проверку какое число: отрицательное или положительное
    else
        i=1;
    for (i;i<len;i++)
    {
        switch (str[i])
        {
            case '1':
                temp+=1*pow(10.0,double(len-i-1));
                break;
            case '2':
                temp+=2*pow(10.0,double(len-i-1));
                break;
            case '3':
                temp+=3*pow(10.0,double(len-i-1));
                break;
            case '4':
                temp+=4*pow(10.0,double(len-i-1));
                break;
            case '5':
                temp+=5*pow(10.0,double(len-i-1));
                break;
            case '6':
                temp+=6*pow(10.0,double(len-i-1));
                break;
            case '7':
                temp+=7*pow(10.0,double(len-i-1));
                break;
            case '8':
                temp+=8*pow(10.0,double(len-i-1));
                break;
            case '9':
                temp+=9*pow(10.0,double(len-i-1));
                break;
            case '0':
                temp+=0*pow(10.0,double(len-i-1));
                break;
        }
    }
    if (str[0]=='-')
        temp=-temp;
    //если число отрицательное
    return temp;
}
 
void AnalizingStr(char * str, int * arr1, int n)
{
    int i=0;
    char * tmpstr = new char [10];
    //временная строка для каждого числа из файла
    int j=0;
    int k=0;
    while (str[i]!='\0')
    {
        if (str[i]!=' ')
        {
            tmpstr[j]=str[i];
            j++;
            if ((str[i+1]==' ') || (str[i+1]=='\0'))
            {
                tmpstr[j]='\0';
                j=0;
                arr1[k]=StrToInt(tmpstr);
                //вызов функции перевода числа из символьного типа в числовой
                k++;
            }
        }
        i++;
    }
    delete [] tmpstr;
 
}
 
 
 
//Собсно сам массив
int arr1 [razmer]; 
 
//Это глобальная величина- произведение чисел
int pr; 
 
//параметр это индекс числа в массиве
//(в нашем случае индексы будут 0, 1, 2, 3) 
bool f (int index) {
 
 
 //В функции "сближаемся", идём от начала к концу,
 //если встретились- возвращаем true
 if (index==razmer/2)
  return true;
 else 
  if (arr1 [index]* arr1 [razmer- index- 1]!= pr) 
   return false;
  else 
   return (f(index+ 1));
 printf ("%d\n", f(1));  
 
}
файл: main.cpp
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
#include <iostream>
#include <stdio.h>
#include <conio.h>
#include "Function.h"
#define razmer 8
 
using namespace std;
 
void main(int argc, char* argv[])
{
    char * filestr = new char [100];
    //строка для ввода адреса к файлу
    cout<<"Input address to file with data:"<<endl;
    cin>>filestr;
    FILE * fr = fopen(filestr,"r");
 
    if (!fr)
    {
        //если файл не был найден
        delete [] filestr;
        cout<<"File not found! Program will close!"<<endl;
        system("pause");
        return;
    }
    delete [] filestr;
    cout<<endl;
    int count=0;
    //переменная для количества чисел в файле
    int countch=0;
    //переменная для количества символов в файле
    char ch;
    while ((ch=fgetc(fr))!='\n')
    {
        countch++;
        if (ch==' ')
            count++;
    }
    if ((count+1)%2!=0)
    {
        //если количество чисел в файле не четное
        fclose(fr);
        cout<<"Amount of counts is not uneven. Please, correct the input data and restart this program."<<endl;
        return;
    }
    char * str = new char [countch+1];
    int * arr1 = new int [count+1];
    fseek(fr,0,SEEK_SET);
    //смещаем указатель на файл
    fgets(str,countch+1,fr);
    //считываем первую строку из файла с числами
    AnalizingStr(str,arr1,count+1);
    //вызов функции для анализа и перевода чисел из символьного типа в числовой
    
 
 
 
    cout<<"Input array:"<<endl;
    for (int i=0;i<count+1;i++)
        cout<<arr1[i]<<" ";
    //вывод исходного массива
    cout<<endl;
 
 
    int pr;
        //НАйдём произведение чисел
    pr= arr1[0]* arr1[razmer- 1];
    
    printf ("%d\n", f(1));                //ооошииибкааа
    
    delete [] str;
    delete [] arr1;
    //delete [] arr2;
    fclose(fr);
    getch();
}
Добавлено через 2 минуты
c 90 по 113 строку вставил Ваш кусок в файл Фанкшн
с 65 по 69 строку вставил Ваш кусок в файл Майн, ошибка в 69 строке. не определён индификатор пишет. Может из-за области видимости в мейне не передаётся эта функция?

Можете дать подсказку, как ввести программу в эксплуатацию?
0
kravam
быдлокодер
1705 / 892 / 45
Регистрация: 04.06.2008
Сообщений: 5,524
22.04.2013, 17:49 #24
А где файл Function.h?
0
lj23lj
1 / 1 / 0
Регистрация: 15.11.2011
Сообщений: 34
22.04.2013, 17:51  [ТС] #25
Я думал не надо. Там ж прототипы только.
файл Function.h
C++
1
2
3
4
5
6
7
8
9
10
11
#ifndef _FUNCTION_
#define _FUNCTION_
 
int StrToInt(char * str);
//функция для перевода числа из символьного типа в числовой
void AnalizingStr(char * str, int * arr1, int n);
//функция для выделения чисел из строки в файле
//int Mult(int * arr1, int * arr2, int n, int & m);
//функция для формирования пар из исходного массива
 
#endif
ну плюс ещё исходные данные берутся из файла текстового в директории с файлами .cpp
0
kravam
быдлокодер
1705 / 892 / 45
Регистрация: 04.06.2008
Сообщений: 5,524
22.04.2013, 18:02 #26
Цитата Сообщение от lj23lj Посмотреть сообщение
ошибка в 69 строке. не определён индификатор пишет.
Так он на самом деле на определён. Где определёна функция f, скажи мне?
0
lj23lj
1 / 1 / 0
Регистрация: 15.11.2011
Сообщений: 34
22.04.2013, 18:14  [ТС] #27
Ой она в другом файле. тогда я в заголовочном её прототип напишу и вызову эту функцию в main.

Добавлено через 2 минуты
kravam, вышло. теперь программа согласно коду распечатывает 1. А как теперь сделать вывод пар в новом коде?
0
kravam
быдлокодер
1705 / 892 / 45
Регистрация: 04.06.2008
Сообщений: 5,524
22.04.2013, 18:20 #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
37
38
39
40
41
42
43
44
#include <stdio.h>
 
#define razmer 8
 
//Собсно сам массив
int array [razmer]= {1, 2, 3, 5, 6, 10, 15, 30}; 
 
//Это глобальная величина- произведение чисел
int pr; 
 
//параметр это индекс числа в массиве
//(в нашем случае индексы будут 0, 1, 2, 3) 
bool f (int index) {
 
 
 //В функции "сближаемся", идём от начала к концу,
 //если встретились- возвращаем true
 if (index==razmer/2)
  return true;
 else 
  if (array [index]* array [razmer- index- 1]!= pr) 
   return false;
  else 
   return (f(index+ 1));
}
 
//++++++++++++++++++++++++++++++++++++++++++++++++
 
int main()
{
    //НАйдём произведение чисел
    pr= array[0]* array[razmer- 1];
    
    int t= f (1);
    printf ("%d\n", t);
    
    if (t)
    for (int i= 0; i< razmer/2; i++) {
     printf ("%d %d\n", array[i], array [razmer- i- 1]);
    }
    
    getchar ();
    return 0;
}
1
lj23lj
1 / 1 / 0
Регистрация: 15.11.2011
Сообщений: 34
22.04.2013, 18:40  [ТС] #29
kravam, Спасибо большое.
Т.е в ответ на исходные данные (4 6 3 2 1 12), программа выдаёт:
1 //значит, что пары нашлись

и

4 -1414812757
6 -33686019
3 12
2 1

4,6,3,2,1,12 это как раз и есть значения, из которых формируется произведение. А два посторонних значения - это издержки?? И т.е надо как-то придумать, как из данных значений составить пары?

И ещё, а рекурсивность где конкретно проявляется?
0
kravam
быдлокодер
1705 / 892 / 45
Регистрация: 04.06.2008
Сообщений: 5,524
22.04.2013, 18:54 #30
Ты на мой код посмотри, у меня массив отсортированный, а
4 6 3 2 1 12
неотсортированный. Отсортируй, вставь в мою программу, измени razmer и всё будет круто. Рекурсивность в том проявляется, что f вызывает сама себя
0
22.04.2013, 18:54
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.04.2013, 18:54
Привет! Вот еще темы с ответами:

Создать динамический массив. ввод,вывод и обработку элементов массива реализовать через функции - C++
создать динамический массив. ввод,вывод и обработку элементов массива реализовать через функции

НОД через рекурсию - C++
Нужно написать программу для нахождения НОД через рекурсию по такому алгоритму: 1) задать два числа; 2) если числа равны, то взять...

последовательность через рекурсию - C++
нужна ваша помощь задача такая: написать рекурсивную функцию для ввода последовательности чисел и вывода ее на экран в обратном...

поиск через рекурсию - C++
С помощью массива структур описать каталог компьютерных игр, предусмотрев следующие характеристики: название, производитель, год издания,...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru