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

Одномерные массивы. Вычислить m значений функции f(x) на отрезке [a, b] - C++

Восстановить пароль Регистрация
 
Folayt
 Аватар для Folayt
1 / 2 / 1
Регистрация: 25.10.2012
Сообщений: 107
05.06.2013, 19:04     Одномерные массивы. Вычислить m значений функции f(x) на отрезке [a, b] #1
a.Вычислить m значений функции f(x) на отрезке [a, b]. Вычисление величины f(x) с оформить в виде функции. Аргументы и значения функций сохранить в отдельных массивах.
b.В массиве значений найти минимальный и максимальный элементы.
c.Найти среднее значение элементов массива значений функции, и подсчитать количество элементов больших среднего значения.

Функция f(x)
5.2 + 3x – tg(x)/2

a=0.5
b=1
m=10

ПОМОГИТЕ ПОЖАЛУЙСТА БУДУ БЛАГОДАРЕН!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.06.2013, 19:04     Одномерные массивы. Вычислить m значений функции f(x) на отрезке [a, b]
Посмотрите здесь:

C++ Вычислить 18 значений функции ax^2+bx+c на отрезке [e,f], сохранить их в массиве Y и определить, имеет ли уравнение ax^2+bx+c=0 на отрезке [e,f] по крайней мере хотя бы один корень.
Необходимо вычислить N значений функции на отрезке C++
C++ Одномерные массивы. Вычислить 30 значений функции
C++ Оброботка одномерных массивов (Вычислить m значений функции f(x) на отрезке [a, b], найти элементы, среднее значение)
Вычислить m значений функции f(x) на отрезке [a, b]. Вычисление величины f(x) оформить в виде функции C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Кудаив
328 / 405 / 24
Регистрация: 27.05.2012
Сообщений: 1,162
Завершенные тесты: 2
05.06.2013, 19:06     Одномерные массивы. Вычислить m значений функции f(x) на отрезке [a, b] #2
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
#include <cmath>
#include <vector>
#include <utility>
 
std::vector<std::pair<double, double> > func(double a, double b, unsigned step);
 
int main()
{
    std::vector<std::pair<double, double> > Output = func(0.5, 1, 10);
    return 0;
}
 
std::vector<std::pair<double, double> > func(double a, double b, unsigned step)
{
    std::vector<std::pair<double, double> > output;
    double value = 0.0;
    for(double i = a; i <= b; i += step)
    {
        value = 5.2 + 3 * i - tan(i)/2;
        output.push_back(std::make_pair(i, value));
    }
    return output;
}
faLek
99 / 100 / 7
Регистрация: 06.03.2012
Сообщений: 478
05.06.2013, 19:13     Одномерные массивы. Вычислить m значений функции f(x) на отрезке [a, b] #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
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 <iostream>
#include <ctime>
#include <iomanip>
#include <cmath>
 
using namespace std;
 
void A ();
void B (int *arr);
void C (int *arr,const int N = 10);
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale (LC_ALL,"Russian");
 
    A ();
 
    const int m = 10;
    int massiv[m];
 
    for (int i = 0;i<m;i++)
    {
        massiv[i] = -10 + rand() % 21;
        cout<<setw (3)<<massiv[i];
    }
    cout<<endl;
 
    B (massiv);
 
    system ("pause");
    return 0;
}
 
void B (int *arr)
{
    const int N = 10;
    int min,max;
 
    min = arr[0];
    max = arr[0];
    for (int i = 0;i<N;i++)
    {
        if (arr[i] < min)
            min = arr[i];
        if (arr[i] > max)
            max = arr[i];
    }
 
    cout<<"Минимальный элемент: "<<min;
        cout<<endl;
    cout<<"Максимальные элемент: "<<max;
        cout<<endl;
}
 
void A ()
{
    double f,a = 0.5,b = 1.0,sum = 0,sr;
    const int N = 10;
    double massiv[N];
 
    for (double x = a;x <= b;x += 0.1)
    {
        f = 5.2 + 3*x - (tan (x) / 2);  
        for (int i = 0;i<x;i++)
        {
            massiv[i] = f;
            cout<<" "<<massiv[i];
            sum += massiv[i];
            sr = sum / x;
        }
    }
 
    cout<<endl;
    cout<<"Среднее арифметическое = "<<sr;
    cout<<endl;
}
Добавлено через 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
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
#include <iostream>
#include <ctime>
#include <iomanip>
#include <cmath>
 
using namespace std;
 
void A ();
void B (int *arr);
void C (int *arr,const int N = 10);
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale (LC_ALL,"Russian");
 
    A ();
 
    const int m = 10;
    int massiv[m];
 
    for (int i = 0;i<m;i++)
    {
        massiv[i] = -10 + rand() % 21;
        cout<<setw (3)<<massiv[i];
    }
    cout<<endl;
 
    B (massiv);
 
    system ("pause");
    return 0;
}
 
void B (int *arr)
{
    const int N = 10;
    int min,max;
 
    min = arr[0];
    max = arr[0];
    for (int i = 0;i<N;i++)
    {
        if (arr[i] < min)
            min = arr[i];
        if (arr[i] > max)
            max = arr[i];
    }
 
    cout<<"Минимальный элемент: "<<min;
        cout<<endl;
    cout<<"Максимальные элемент: "<<max;
        cout<<endl;
}
 
void A ()
{
    double f,a = 0.5,b = 1.0,sum = 0,sr,kol = 0;
    const int N = 10;
    double massiv[N];
 
    for (double x = a;x <= b;x += 0.1)
    {
        f = 5.2 + 3*x - (tan (x) / 2);  
        for (int i = 0;i<x;i++)
        {
            massiv[i] = f;
            cout<<" "<<massiv[i];
            sum += massiv[i];
            sr = sum / x;
            if (sr < massiv[i])
                kol++;
        }
    }
 
    cout<<endl;
    cout<<"Среднее арифметическое = "<<sr;
    cout<<endl;
    cout<<"Колличество элментов больше среднего: "<<kol;
    cout<<endl;
}
Добавлено через 40 секунд
дописал во втором колличество элементов больше среднего
Folayt
 Аватар для Folayt
1 / 2 / 1
Регистрация: 25.10.2012
Сообщений: 107
05.06.2013, 19:16  [ТС]     Одномерные массивы. Вычислить m значений функции f(x) на отрезке [a, b] #4
Цитата Сообщение от faLek Посмотреть сообщение
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 <iostream>
#include <ctime>
#include <iomanip>
#include <cmath>
 
using namespace std;
 
void A ();
void B (int *arr);
void C (int *arr,const int N = 10);
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale (LC_ALL,"Russian");
 
    A ();
 
    const int m = 10;
    int massiv[m];
 
    for (int i = 0;i<m;i++)
    {
        massiv[i] = -10 + rand() % 21;
        cout<<setw (3)<<massiv[i];
    }
    cout<<endl;
 
    B (massiv);
 
    system ("pause");
    return 0;
}
 
void B (int *arr)
{
    const int N = 10;
    int min,max;
 
    min = arr[0];
    max = arr[0];
    for (int i = 0;i<N;i++)
    {
        if (arr[i] < min)
            min = arr[i];
        if (arr[i] > max)
            max = arr[i];
    }
 
    cout<<"Минимальный элемент: "<<min;
        cout<<endl;
    cout<<"Максимальные элемент: "<<max;
        cout<<endl;
}
 
void A ()
{
    double f,a = 0.5,b = 1.0,sum = 0,sr;
    const int N = 10;
    double massiv[N];
 
    for (double x = a;x <= b;x += 0.1)
    {
        f = 5.2 + 3*x - (tan (x) / 2);  
        for (int i = 0;i<x;i++)
        {
            massiv[i] = f;
            cout<<" "<<massiv[i];
            sum += massiv[i];
            sr = sum / x;
        }
    }
 
    cout<<endl;
    cout<<"Среднее арифметическое = "<<sr;
    cout<<endl;
}
Добавлено через 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
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
#include <iostream>
#include <ctime>
#include <iomanip>
#include <cmath>
 
using namespace std;
 
void A ();
void B (int *arr);
void C (int *arr,const int N = 10);
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale (LC_ALL,"Russian");
 
    A ();
 
    const int m = 10;
    int massiv[m];
 
    for (int i = 0;i<m;i++)
    {
        massiv[i] = -10 + rand() % 21;
        cout<<setw (3)<<massiv[i];
    }
    cout<<endl;
 
    B (massiv);
 
    system ("pause");
    return 0;
}
 
void B (int *arr)
{
    const int N = 10;
    int min,max;
 
    min = arr[0];
    max = arr[0];
    for (int i = 0;i<N;i++)
    {
        if (arr[i] < min)
            min = arr[i];
        if (arr[i] > max)
            max = arr[i];
    }
 
    cout<<"Минимальный элемент: "<<min;
        cout<<endl;
    cout<<"Максимальные элемент: "<<max;
        cout<<endl;
}
 
void A ()
{
    double f,a = 0.5,b = 1.0,sum = 0,sr,kol = 0;
    const int N = 10;
    double massiv[N];
 
    for (double x = a;x <= b;x += 0.1)
    {
        f = 5.2 + 3*x - (tan (x) / 2);  
        for (int i = 0;i<x;i++)
        {
            massiv[i] = f;
            cout<<" "<<massiv[i];
            sum += massiv[i];
            sr = sum / x;
            if (sr < massiv[i])
                kol++;
        }
    }
 
    cout<<endl;
    cout<<"Среднее арифметическое = "<<sr;
    cout<<endl;
    cout<<"Колличество элментов больше среднего: "<<kol;
    cout<<endl;
}
Добавлено через 40 секунд
дописал во втором колличество элементов больше среднего
а здесь почему то рандом не работает
при каждом запуске одинаковое значение
faLek
99 / 100 / 7
Регистрация: 06.03.2012
Сообщений: 478
05.06.2013, 19:23     Одномерные массивы. Вычислить m значений функции f(x) на отрезке [a, b] #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
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
#include <iostream>
#include <ctime>
#include <iomanip>
#include <cmath>
 
using namespace std;
 
void A ();
void B (int *arr);
void C (int *arr,const int N = 10);
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale (LC_ALL,"Russian");
    srand (time(NULL));
 
    A ();
 
    const int m = 10;
    int massiv[m];
 
    for (int i = 0;i<m;i++)
    {
        massiv[i] = -10 + rand() % 21;
        cout<<setw (3)<<massiv[i];
    }
    cout<<endl;
 
    B (massiv);
 
    system ("pause");
    return 0;
}
 
void B (int *arr)
{
    const int N = 10;
    int min,max;
 
    min = arr[0];
    max = arr[0];
    for (int i = 0;i<N;i++)
    {
        if (arr[i] < min)
            min = arr[i];
        if (arr[i] > max)
            max = arr[i];
    }
 
    cout<<"Минимальный элемент: "<<min;
        cout<<endl;
    cout<<"Максимальные элемент: "<<max;
        cout<<endl;
}
 
void A ()
{
    double f,a = 0.5,b = 1.0,sum = 0,sr,kol = 0;
    const int N = 10;
    double massiv[N];
 
    for (double x = a;x <= b;x += 0.1)
    {
        f = 5.2 + 3*x - (tan (x) / 2);  
        for (int i = 0;i<x;i++)
        {
            massiv[i] = f;
            cout<<" "<<massiv[i];
            sum += massiv[i];
            sr = sum / x;
            if (sr < massiv[i])
                kol++;
        }
    }
 
    cout<<endl;
    cout<<"Среднее арифметическое = "<<sr;
    cout<<endl;
    cout<<"Колличество элментов больше среднего: "<<kol;
    cout<<endl;
}
Folayt
 Аватар для Folayt
1 / 2 / 1
Регистрация: 25.10.2012
Сообщений: 107
05.06.2013, 19:31  [ТС]     Одномерные массивы. Вычислить m значений функции f(x) на отрезке [a, b] #6
C++
1
 sr = sum / f
так правильнее будет

Добавлено через 1 минуту
Спасибо за помошь
Yandex
Объявления
05.06.2013, 19:31     Одномерные массивы. Вычислить m значений функции f(x) на отрезке [a, b]
Ответ Создать тему
Опции темы

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