📜  三角形的剩余两条边距给定边及其相邻角的长度

📅  最后修改于: 2021-10-23 08:53:21             🧑  作者: Mango

给定三角形的边a及其相邻角BC的长度,任务是找到三角形的其余两条边。

方法:

  1. 剩下的角可以通过三角形中的角和定理来计算:
  2. 三角形的另外两条边可以使用正弦公式计算:

下面是上述方法的实现:

C++
// C++ program for above approach
#include
using namespace std;
 
// Function for computing other
// 2 side of the trianlgle
void findSide(float a, float B, float C)
{
     
    // Computing angle C
    float A = 180 - C - B;
     
    // Converting A in to radian
    float radA = M_PI * (A / 180);
     
    // Converting B in to radian
    float radB = M_PI * (B / 180);
     
    // Converting C in to radian
    float radC = M_PI * (C / 180);
     
    // Computing length of side b
    float b = a / sin(radA) * sin(radB);
     
    // Computing length of side c
    float c = a / sin(radA) * sin(radC);
     
    cout << fixed << setprecision(15) << b << " ";
    cout << fixed << setprecision(15) << c;
}
 
// Driver code
int main()
{
    int a = 12, B = 60, C = 30;
     
    // Calling function
    findSide(a, B, C);
}
 
// This code is contributed by ishayadav181


Java
// Java program for above approach
import java.util.*;
 
class GFG{
 
// Function for computing other
// 2 side of the trianlgle
static void findSide(double a, double B,
                     double C)
{
     
    // Computing angle C
    double A = 180 - C - B;
     
    // Converting A in to radian
    double radA = (Math.PI * (A / 180));
     
    // Converting B in to radian
    double radB = (Math.PI * (B / 180));
     
    // Converting C in to radian
    double radC = (Math.PI * (C / 180));
     
    // Computing length of side b
    double b = (a / Math.sin(radA) *
                    Math.sin(radB));
     
    // Computing length of side c
    double c = (a / Math.sin(radA) *
                    Math.sin(radC));
     
    System.out.printf("%.15f", b);
    System.out.printf(" %.15f", c);
}
 
// Driver code
public static void main(String[] args)
{
    int a = 12, B = 60, C = 30;
     
    // Calling function
    findSide(a, B, C);
}
}
 
// This code is contributed by Amit Katiyar


Python3
# Python3 program for above approach
import math
 
# Function for computing other
# 2 side of the trianlgle
def findSide(a, B, C):
 
    # computing angle C
    A = 180-C-B
 
    # converting A in to radian
    radA = math.pi *(A / 180)
 
    # converting B in to radian
    radB = math.pi *(B / 180)
 
    # converting C in to radian
    radC = math.pi *(C / 180)
 
    # computing length of side b
    b = a / math.sin(radA)*math.sin(radB)
 
    # computing length of side c
    c = a / math.sin(radA)*math.sin(radC)
 
    return b, c
 
# driver program
a = 12
B = 60
C = 30
 
# calling function
b, c = findSide(a, B, C)
print(b, c)


C#
// C# program for above approach
using System;
class GFG{
 
// Function for computing other
// 2 side of the trianlgle
static void findSide(float a,
                     double B, double C)
{   
  // Computing angle C
  double A = 180 - C - B;
 
  // Converting A in to radian
  double radA = (Math.PI * (A / 180));
 
  // Converting B in to radian
  double radB = (Math.PI * (B / 180));
 
  // Converting C in to radian
  double radC = (Math.PI * (C / 180));
 
  // Computing length of side b
  double b = (a / Math.Sin(radA) *
              Math.Sin(radB));
 
  // Computing length of side c
  double c = (a / Math.Sin(radA) *
              Math.Sin(radC));
 
  Console.Write("{0:F15}", b);
  Console.Write("{0:F15}", c);
}
 
  // Driver code
  public static void Main(String[] args)
  {
    int a = 12, B = 60, C = 30;
 
    // Calling function
    findSide(a, B, C);
  }
}
 
// This code is contributed by 29AjayKumar


Javascript

// Javascript program for above approach
 
// Function for computing other
// 2 side of the trianlgle
function findSide(a, B, C)
{
     
    // Computing angle C
    var A = 180 - C - B;
     
    // Converting A in to radian
    var radA = Math.PI * (A / 180);
     
    // Converting B in to radian
    var radB = Math.PI * (B / 180);
     
    // Converting C in to radian
    var radC = Math.PI * (C / 180);
     
    // Computing length of side b
    var b = a / Math.sin(radA) * Math.sin(radB);
     
    // Computing length of side c
    var c = a / Math.sin(radA) * Math.sin(radC);
     
    document.write( b + " ");
    document.write( c);
}
 
// Driver code
var a = 12, B = 60, C = 30;
 
// Calling function
findSide(a, B, C);
 
10.392304845413264 5.999999999999999


输出:

10.392304845413264 5.999999999999999

时间复杂度: O(1)
辅助空间: O(1)

如果您希望与专家一起参加现场课程,请参阅DSA 现场工作专业课程学生竞争性编程现场课程