Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Центр помощи > [C] [Треугольник - из отрезков]


Автор: Revan 4.6.2009, 17:15
Даны числа l1, а1,l2,a2,l3,a3, определяющие соответственно длины трех отрезков прямых и углы их наклона к оси абсцисс Ох. Выяснить, можно ли из этих отрезков построить треугольник путем    их параллельного перемещения по координатной плоскости.

Автор: Dmi3ev 4.6.2009, 17:25
Revan, точно решал такую задачу и выкладывал решение на форуме, так что если тебе это очень надо и ты не ленивый, то залезь в мой Профиль-Сообщения, и ищи там...

Добавлено через 5 минут и 34 секунды
нашел у себя на компе... я компилил в VS 2008, поэтому, если че инкулуды подрихтуешь, а так прога рабочая вроде...
Код

#include "stdafx.h"
#include <iostream>
#define _USE_MATH_DEFINES
#include <math.h>


using namespace std;

struct piece
{
    double len;
    double ang;
};

double my_torad(double a)
{
return ((a*M_PI)/180);
}

bool mycheck(piece a, piece b, piece c)
{
    if (a.ang==b.ang || a.ang==c.ang || b.ang==c.ang)
        return false;

    double res1=pow(c.len, 2)+pow(b.len, 2)-2*cos(my_torad(c.ang-b.ang))*c.len*b.len;
    double res2=pow(c.len, 2)+pow(b.len, 2)-2*cos(my_torad(180-(c.ang-b.ang)))*c.len*b.len;
    double myres=pow(a.len, 2);
    cout<<res1<<"   "<<res2<<"   "<<pow(a.len, 2)<<endl;
    if(pow(a.len, 2)==pow(c.len, 2)+pow(b.len, 2)-2*cos(my_torad(c.ang-b.ang))*c.len*b.len)||
       pow(a.len, 2)==pow(c.len, 2)+pow(b.len, 2)-2*cos(my_torad(180-(c.ang-b.ang)))*c.len*b.len))
    {
        cout<<"ok"<<endl;
        return true;
    }
    else
        return false;
}

int _tmain()
{
    const int n=3;

    piece* mypiece;
    mypiece=new piece[n];
    
    for (int i=0; i<n; i++)
    {
        cout<<"Piece"<<i+1<<": "<<endl;
        cout<<"len=";
        cin>>mypiece[i].len;
        cout<<"ang=";
        cin>>mypiece[i].ang;
        cout<<endl;
    }
    if (mycheck(mypiece[0], mypiece[1], mypiece[2]))
        cout<<"yes"<<endl;
    else
        cout<<"no"<<endl;
    cout<<endl;
    system("pause");
    return 0;
}

Автор: Revan 11.6.2009, 01:34
Как всегда прошу перевести на чистый С...Спасибо... smile 

Автор: Dov 11.6.2009, 19:34
Цитата(Revan @  11.6.2009,  01:34 Найти цитируемый пост)
Как всегда прошу перевести на чистый С

Самому уже пора это делать.  smile 
Код
#define M_PI 3.141592

struct piece
{
    float    len;
    float    ang;
};

float my_torad( float a )
{
    return ( ( a * M_PI ) / 180 );
}

int mycheck( piece a, piece b, piece c )
{
    if( a.ang == b.ang || a.ang == c.ang || b.ang == c.ang )
        return 0;

    float res1  = pow(c.len, 2) + pow(b.len, 2) - 2 * cos(my_torad(c.ang - b.ang)) * c.len *b.len;
    float res2  = pow(c.len, 2) + pow(b.len, 2) - 2 * cos(my_torad(180 - (c.ang - b.ang))) * c.len *b.len;
    float myres = pow( a.len, 2 );

    printf("%f   %f   %f\n", res1, res2, myres);

    if( myres == res1 || myres == res2)
    {
        puts("ok");
        return 1;
    }

    return 0;
}

int main()
{
    piece mypiece[3];
    int   i;

    for( i = 0; i < 3; i++ )
    {
        printf( "Piece %d:\n", i + 1 );
        printf( "len = " );
        scanf ( "%f", &mypiece[i].len );
        printf( "ang = ");
        scanf ( "%f", &mypiece[i].ang );
        puts  ( "" );
    }

    puts( mycheck( mypiece[0], mypiece[1], mypiece[2] ) ? "\nyes\n" : "\nno\n" );

    return 0;
}

Автор: Revan 11.6.2009, 20:11
Я там напереведу)) Ещё опыта такого нет...

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)