题目

将三角形的六要素只留下三个已知条件,

问有多少种情况,多组询问


分析

首先分类讨论一下(对新高一不友好,比如说我)。

前置知识:

  1. 正弦定理:
\[\frac{a}{sinA}=\frac{b}{sinB}=\frac{c}{sinC}=2r(外接圆的直径)
\]

正弦定理的话应该可以通过做高或者外接圆证明,详见百度百科

  1. 大边对大角,可以通过上面的正弦定理意会一下,三角形内角越大,

    那么它所对应的\(sin\)值越大,根据正弦定理可以知道它的对边也会越大,反过来显然
  2. 余弦定理:
\[cosA=\frac{b^2+c^2-a^2}{2bc}\\
cosB=\frac{a^2+c^2-b^2}{2ac}\\
cosC=\frac{a^2+b^2-c^2}{2ab}
\]

此证明详见百度百科,新高一什么都不会呢

然后具体分成如下四种情况,

  1. 只知道三条边:两边之和均大于第三边为1,否则为0
  2. 只知道三个角:三角形内角和是180度即无限种(相似三角形),否则为0
  3. 只知道两个角,一条边:如果现在知道的两个角的和不小于180度为0,

    否则为1,因为三个角都能求出来,且知道一条边,可以通过大边对大角证明
  4. 只知道一个角,两条边:

    (1). 如果这个角是夹角只有一种情况,根据余弦定理可以将第三条边求出来,

    并且转换成第一个问题,显然计算后两边之和均会大于第三边

    (2). 如果这个角不是夹角,那又要分类讨论:

    如果已知角是直角或者钝角根据大边对大角

    可以知道当已知角的对边长度不超过另一条边无解,因为三角形内角等于180度

    否则答案为1

    如果已知角是锐角,设已知的角为\(\angle A\),它所对的边为\(a\),并且另一条已知边为\(b\)

    首先可以根据正弦定理算出\(sinB\),显然它是一个正数,由于\(sinB\)的值域应为\((0,1]\)

    超过值域无解,\(sinB=1\)(直角)只有一种情况,然后根据大边对大角,

    如果\(a>=b\)只有一种情况,否则有两种情况(一个锐角一个钝角)

    由于C++精度存在一定误差所以还要设置\(eps\)

代码

#include <cstdio>
#include <cctype>
#include <cmath>
#define rr register
using namespace std;
const double pi=acos(-1.0);
const double eps=1e-8;
inline signed iut(){
rr int ans=0,f=1; rr char c=getchar();
while (!isdigit(c)) f=(c=='-')?-f:f,c=getchar();
while (isdigit(c)) ans=(ans<<3)+(ans<<1)+(c^48),c=getchar();
return ans*f;
}
inline void doit1(int a,int b,int A){
rr double sinB=b*sin(A*pi/180)/a;
if (A>=90){
printf("%d\n",a>b);
return;
}else{
if (sinB-1>eps) printf("0\n");
else if (fabs(sinB-1)<eps) printf("1\n");
else if (a>=b) printf("1\n");
else printf("2\n");
return;
}
}
signed main(){
for (rr int T=iut();T;--T){
rr int a=iut(),b=iut(),c=iut(),A=iut(),B=iut(),C=iut();
if ((~a)&&(~b)&&(~c)){
if (a+b<=c||b+c<=a||a+c<=b) printf("0\n");
else printf("1\n");
continue;
}
if ((~A)&&(~B)&&(~C)){
if (A+B+C!=180) printf("0\n");
else printf("syksykCCC\n");
continue;
}
if (a*b*c<0){
if ((A>0&&b*c>0)||(B>0&&a*c>0)||(C>0&&b*a>0)) printf("1\n");
else if (B>0&&b*c>0) doit1(b,c,B);
else if (C>0&&b*c>0) doit1(c,b,C);
else if (A>0&&a*b>0) doit1(a,b,A);
else if (B>0&&a*b>0) doit1(b,a,B);
else if (A>0&&a*c>0) doit1(a,c,A);
else if (C>0&&a*c>0) doit1(c,a,C);
continue;
}
if (A*B*C<0){
if (B+C>=180||A+B>=180||A+C>=180) printf("0\n");
else printf("1\n");
continue;
}
}
return 0;
}

#正余弦定理#牛客练习赛71 B 烙印的更多相关文章

  1. 牛客练习赛71 数学考试 题解(dp)

    题目链接 题目大意 要你求出有多少个长度为n的排列满足m个限制条件 第i个限制条件 p[i]表示前 p[i]个数不能是1-p[i]的排列 题目思路 这个感觉是dp但是不知道怎么dp 首先就是要明白如果 ...

  2. 牛客练习赛71 C.数学考试 (DP,容斥原理)

    题意:RT 题解:先对\(p\)排个序,然后设\(dp[i]\)表示前\(i-1\)个\(p[i]\)满足条件但是\(p[i]\)不满足,即在\([1,p[i]]\)中不存在从\(p[1]\)到\(p ...

  3. 牛客练习赛48 A· 小w的a+b问题 (贪心,构造,二进制)

    牛客练习赛48 A· 小w的a+b问题 链接:https://ac.nowcoder.com/acm/contest/923/A来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C ...

  4. 【并查集缩点+tarjan无向图求桥】Where are you @牛客练习赛32 D

    目录 [并查集缩点+tarjan无向图求桥]Where are you @牛客练习赛32 D PROBLEM SOLUTION CODE [并查集缩点+tarjan无向图求桥]Where are yo ...

  5. 牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 逻辑,博弈 B

    牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 https://ac.nowcoder.com/acm/contest/218/B 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 2621 ...

  6. 牛客练习赛31 D 神器大师泰兹瑞与威穆 STL,模拟 A

    牛客练习赛31 D 神器大师泰兹瑞与威穆 https://ac.nowcoder.com/acm/contest/218/D 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 26214 ...

  7. 最小生成树--牛客练习赛43-C

    牛客练习赛43-C 链接: https://ac.nowcoder.com/acm/contest/548/C 来源:牛客网 题目描述 ​ 立华奏是一个刚刚开始学习 OI 的萌新. 最近,实力强大的 ...

  8. 牛客练习赛28-B(线段树,区间更新)

    牛客练习赛28 - B 传送门 题目 qn姐姐最好了~ ​ qn姐姐给你了一个长度为n的序列还有m次操作让你玩, ​ 1 l r 询问区间[l,r]内的元素和 ​ 2 l r 询问区间[l,r]内的 ...

  9. 牛客练习赛26:D-xor序列(线性基)

    链接:牛客练习赛26:D-xor序列(线性基) 题意:小a有n个数,他提出了一个很有意思的问题:他想知道对于任意的x, y,能否将x与这n个数中的任意多个数异或任意多次后变为y 题解:线性基 #inc ...

  10. [堆+贪心]牛客练习赛40-B

    传送门:牛客练习赛40 题面: 小A手头有 n 份任务,他可以以任意顺序完成这些任务,只有完成当前的任务后,他才能做下一个任务 第 i 个任务需要花费  x_i 的时间,同时完成第 i 个任务的时间不 ...

随机推荐

  1. vscode添加gitbash终端方法

    1.打开vscode 2.点击文件,ctrl+, 3.搜索shell windows { ... // 添加如下代码 "terminal.integrated.profiles.window ...

  2. auth模块的一些方法

    auth模块 auth模块是cookie和session的升级版,auth模块是对登录认证方法的一种封装,之前我们获取用户输入的用户名及密码后需要自己从user表里查询有没有用户名和密码符合的对象,而 ...

  3. java+mysql实现的公益管理系统

    一功能 1.管理员的登录 2.公益项目的增删改查 3.负责人的增删改查 4.捐款人的增删改查 5.志愿者增删改查 二界面展示 1.欢迎界面 2.登录界面 3.系统首页 4.项目管理 5.负责人管理 6 ...

  4. C C++指针面试题零碎整理

    最基础的指针如下: int a; int* p = &a; 答:p指向a的地址,&是取a的地址.*指的是指针中取内容的符号. 2.str[]和str*的区别: char str1[] ...

  5. React实现导航栏点击高亮

    在jquery中实现导航栏的切换只需要一行代码找到同级其他元素removeClass以及添加点击元素addClass就可以实现了,但是React没法直接找到同级元素,这个时候需要一点js中的思维,根据 ...

  6. 【Azure 应用服务】App Server 部署后,Docker报错,找不到8080端口

    问题描述 App Service for Container.  Docker Image 推送到ACR(向 Azure 容器注册表), 配置App Service并部署成功了.查看Docker日志( ...

  7. [C++逆向] 6 函数的工作原理

    目录 栈帧的形成和关闭 各种调用方式的考察 _stdcall _cdecl _fastcall 使用ebp或者esp寻址 某次调用函数时的栈结构 函数参数 不定长参数 函数的返回值 栈帧的形成和关闭 ...

  8. SQL之 数据库表字段约束与索引

    第三范式 MySQL四种字段约束 主键约束 非空约束 唯一约束 创建索引 添加和删除索引

  9. iview select 下拉 多选 数组 外面包一层 数组改逗分,外层不能用v-model 要用 :value @input,input里面要把对象解构下,才能过验证 - vue

    iview select 下拉 多选 数组 外面包一层 数组改逗分,外层不能用v-model 要用 :value @input,input里面要把对象解构下,才能过验证 - vue

  10. C++学习笔记之高级语法

    目录 高级语法 面向对象--类 对象的属性 运算符重载 拷贝构造函数 IO缓存 头文件的重复包含问题 深拷贝与浅拷贝 面向对象三大特性 高级语法 面向对象--类 C++使用struct.class来定 ...