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

Определить силу трения - C++

Восстановить пароль Регистрация
 
isaak
101 / 38 / 9
Регистрация: 17.10.2010
Сообщений: 634
06.10.2012, 00:35     Определить силу трения #1
Всем доброго время суток. Написать программу определения силы трения http://www.cyberforum.ru/cgi-bin/latex.cgi?{F}_{t}, которая действует на тело массой m, находящейся на наклонной плоскости (угол наклона http://www.cyberforum.ru/cgi-bin/latex.cgi?\alpha). Воспользоваться соотношением
http://www.cyberforum.ru/cgi-bin/latex.cgi?{F}_{t} = k*m*g*\cos(\alpha)для случая, если тело скользит по плоскости, и
http://www.cyberforum.ru/cgi-bin/latex.cgi?{F}_{t} = m*g*\sin(\alpha) если тело находится в покое. Использовать тернарный оператор. Если расписать в проекциях на оси X и Y, то получится на OX: http://www.cyberforum.ru/cgi-bin/latex.cgi?m*a=m*g*\sin(\alpha) - k*N и
на OY: http://www.cyberforum.ru/cgi-bin/latex.cgi?m*g*\cos(\alpha) - N=0 откуда получаем, что
http://www.cyberforum.ru/cgi-bin/latex.cgi?N=m*g*\cos(\alpha) , где N - сила реакции опоры. Если тело покоится,
то http://www.cyberforum.ru/cgi-bin/latex.cgi?m*g*\sin(\alpha) - k*m*g*\cos(\alpha)=0 http://www.cyberforum.ru/cgi-bin/latex.cgi?\Rightarrow  m*g*\sin(\alpha) = k*m*g*\cos(\alpha) и получается, что http://www.cyberforum.ru/cgi-bin/latex.cgi?k = \tan(\alpha), но это не совсем верно так как k еще зависит от материалов из которых тело и наклонная плоскости, сухие и чистые у них поверхности или смазанные или жирные у них поверхности.
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
#include <cmath>
#include <iostream>
using namespace std;
 
template <class T>
bool SafeInput(const char * sMsg, T &val);
 
int main()
{
    setlocale(LC_ALL,"RUS");
    double m = 0;
    double g = 9.81;
    double alpha = 0;
    double k = 0;
    double deg = asin(1.0)/90;
    while(true)
    {
        if(!SafeInput("m = ", m))
            cout<<"input error"<<endl;
        else
        if(m < 0)
            cout<<"m must be positive"<<endl;
        else
        if(!SafeInput("k = ", k))
            cout<<"input error"<<endl;
        else
        if(k < 0)
            cout<<"k must be positive"<<endl;
        else
        if(!SafeInput("alpha(deg) = ", alpha))
            cout<<"input error"<<endl;
        else
       if(fabs(m*g*sin(alpha*deg) - k*m*g*cos(alpha*deg)) < 1E-6)
            cout<<"Fтр = "<<m*g*sin(alpha*deg)<<"No movment"<<endl;
        else
            cout<<"Fтр = "<<k*m*g*cos(alpha*deg)<<endl;
    }
    return 0;
}
 
template <class T>
bool SafeInput(const char * sMsg, T &val)
{
    bool bInput = true;
    cout<<sMsg;
    if(!(cin>>val))
        bInput = false;
    if(!bInput)
    {
        cin.sync();
        cin.clear();
    }
    return bInput;
}
Подскажите пожалуйста как используя тернарный оператор правильно записать решения для случая когда тело скользит и для случая когда тело покоится???? У меня не получается???? Заранее огромное спасибо.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
06.10.2012, 00:35     Определить силу трения
Посмотрите здесь:

C++ Определить силу притяжения F между телами
C++ Определить силу притяжения F между телами массы m1 и m2 , находящимися на расстоянии r друг от друга
C++ Определить силу притяжения между телами массы m1 и m2, находящимися на расстоянии r друг от друга.
Вычислить коэффициент трения C++
Наследование: Определить класс vector2 как вектор на плоскости. Определить для него операции и функции C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
phdef
Сообщений: n/a
06.10.2012, 11:14     Определить силу трения #2
Условная операция Выражение1 ? выражение2 : выражение3 (если значение выражения1 – истина, то вычисляется выражение2, иначе выражение3)
C++
1
2
int i=1, j=5, M; 
M= ( i<j ? i : j); // M=1
-=ЮрА=-
Заблокирован
Автор FAQ
06.10.2012, 11:26     Определить силу трения #3
isaak, вот это условие
Цитата Сообщение от isaak Посмотреть сообщение
if(fabs(m*g*sin(alpha*deg) - k*m*g*cos(alpha*deg)) < 1E-6)
* * * * * * cout<<"Fтр = "<<m*g*sin(alpha*deg)<<"No movment"<<endl;
* * * * else
* * * * * * cout<<"Fтр = "<<k*m*g*cos(alpha*deg)<<endl;
запиши его тернарником + условие покоя можно ещё и упростить
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
#include <cmath>
#include <iostream>
using namespace std;
 
template <class T>
bool SafeInput(const char * sMsg, T &val);
 
int main()
{
    system("chcp 1251");
    //setlocale(LC_ALL,"RUS");
    double m = 0;
    double g = 9.81;
    double alpha = 0;
    double k = 0;
    double deg = asin(1.0)/90;
    while(true)
    {
        if(!SafeInput("m = ", m))
            cout<<"input error"<<endl;
        else
        if(m <= 0)
            cout<<"m must be positive"<<endl;
        else
        if(!SafeInput("k = ", k))
            cout<<"input error"<<endl;
        else
        if(k < 0)
            cout<<"k must be positive"<<endl;
        else
        if(!SafeInput("alpha(deg) = ", alpha))
            cout<<"input error"<<endl;
        else
            (sin(alpha*deg) < k*cos(alpha*deg))
            ?
            cout<<"Fтр = "<<("No movment")
            :
            cout<<"Fтр = "<<(k*m*g*cos(alpha*deg));
            cout<<endl;
    }
    return 0;
}
 
template <class T>
bool SafeInput(const char * sMsg, T &val)
{
    bool bInput = true;
    cout<<sMsg;
    if(!(cin>>val))
        bInput = false;
    if(!bInput)
    {
        cin.sync();
        cin.clear();
    }
    return bInput;
}
m = 5
k = 0.5
alpha(deg) = 15
Fтр = No movment
m =
isaak
101 / 38 / 9
Регистрация: 17.10.2010
Сообщений: 634
06.10.2012, 19:49  [ТС]     Определить силу трения #4
От всей души огромное спасибо -=ЮрА=- !!!!

Добавлено через 6 часов 9 минут
Не хочу создавать новую тему. Задача в чуть чуть отличается от предыдущей. Тело массой m находится на наклонной плоскости (угол наклона http://www.cyberforum.ru/cgi-bin/latex.cgi?\alpha) и привязано с помощью нерастяжимой нити (нить направлена вдоль наклонной плоскости). Коэффициент трения о плоскость равен k. Написать программу, для вычисления силы натяжения нити F. Принять во внимание, что возможны две ситуации. Если http://www.cyberforum.ru/cgi-bin/latex.cgi?\tan(\alpha) < k, натяжение нити равно нулю, т.е. F = 0. В противном случае сила натяжения нити http://www.cyberforum.ru/cgi-bin/latex.cgi?F = m*g*(\sin(\alpha)- k*\cos(\alpha)). использовать тернарный оператор. Опять нужно брать проекции на оси OX и OY.
На OX: http://www.cyberforum.ru/cgi-bin/latex.cgi?{F}_{t} = m*g*\sin(\alpha) - k*N.
На OY: http://www.cyberforum.ru/cgi-bin/latex.cgi?m*g*\cos(\alpha) - N = 0 \Rightarrow N = m*g*\cos(\alpha).
Когда сила натяжения нити равно нулю, т.е. F = 0 получается неравенство:
http://www.cyberforum.ru/cgi-bin/latex.cgi?\tan(\alpha) < k.
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
#include <cmath>
#include <iostream>
using namespace std;
 
template <class T>
bool SafeInput(const char * sMsg, T &val);
 
int main()
{
    setlocale(LC_ALL,"RUS");
    double m = 0;
    double g = 9.81;
    double alpha = 0;
    double k = 0;
    double deg = atan(1.0)/45;
    while(true)
    {
        if(!SafeInput("m = ", m))
            cout<<"input error"<<endl;
        else
        if(m <= 0)
            cout<<"m must be positive"<<endl;
        else
        if(!SafeInput("k = ", k))
            cout<<"input error"<<endl;
        else
        if(k < 0)
            cout<<"k must be positive"<<endl;
        else
        if(!SafeInput("alpha(deg) = ", alpha))
            cout<<"input error"<<endl;
        else
            (tan(alpha*deg) < k)
            ?
            cout<<"Fнт = 0 "<<("Body move")
            :
            cout<<"Fнт = "<<(m*g*(sin(alpha*deg) - k*cos(alpha*deg)));
            cout<<endl;
    }
    return 0;
}
 
template <class T>
bool SafeInput(const char * sMsg, T &val)
{
    bool bInput = true;
    cout<<sMsg;
    if(!(cin>>val))
        bInput = false;
    if(!bInput)
    {
        cin.sync();
        cin.clear();
    }
    return bInput;
}
Проверьте пожалуйста все ли правильно???? Заранее огромное спасибо.
Yandex
Объявления
06.10.2012, 19:49     Определить силу трения
Ответ Создать тему
Опции темы

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