计算三角形面积_三角形怎么算平方

计算三角形面积_三角形怎么算平方参考:已知三点坐标,求三角形面积1:已知直角坐标系3点p(a,b),m(c,d),n(e,f)求三角形pmn面积两倍三角形面积是整型代码模板:llsolve(lla,llb,llc,

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

参考:已知三点坐标,求三角形面积

计算三角形面积_三角形怎么算平方

1: 已知直角坐标系3点p(a,b),m(c,d),n(e,f)求三角形pmn面积

两倍三角形面积是整型
代码模板:

ll solve(ll a,ll b,ll c,ll d,ll e,ll f)//计算两倍三角形面积
{
    return abs(a*d+b*e+c*f-a*f-b*c-d*e);
}

此写法可以不爆long long,之后再除以2即可

2: 若是由三条边求面积,则海伦公式

计算三角形面积_三角形怎么算平方

模板为:

double hailun(double a,double b,double c)
{//保证尽量不爆long long
    double s;
    double pp=(a+b+c)/2.0;
    double s1=sqrt(fabs(pp));
    double s2=sqrt(fabs(pp-a));
    double s3=sqrt(fabs(pp-b));
    double s4=sqrt(fabs(pp-c));
    s=s1*s2*s3*s4;
    return s;
}

3: 判断三点一线

bool judge(node a,node b,node c)
{
    return (c.x-a.x)*(b.y-a.y)-(c.y-a.y)*(b.x-a.x)!=0;
}

参考例题:https://ac.nowcoder.com/acm/contest/327/A

处女座的签到题
时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 262144K,其他语言524288K
64bit IO Format: %lld

题目描述

平面上有n个点,问:平面上所有三角形面积第k大的三角形的面积是多少?

输入描述

第一行T,表示样例的个数。
对于每一组样例,第一行两个整数n和k,
接下来n行,每行两个整数x,y表示点的坐标
T<=80
3<=n<=100
-109<=x,y<=109
对于每一组样例,保证任意两点不重合,且能构成的三角形的个数不小于k

输出描述

对于每一组样例,输出第k大三角形的面积,精确到小数点后两位(四舍五入)。

示例

输入

1
4 3
1 1
0 0
0 1
0 -1

输出

0.50

说明

样例中一共能构成3个三角形,面积分别为0.5,0.5,和1,面积第3大的为0.5
WA点:1,此题用海伦公式会爆double 和 long long
    2,寻找第K大,若不用STL(nth_element),直接sort大法,会超时….

AC代码
#include <bits/stdc++.h>

using namespace std;
#define sc(a) scanf("%d",&a)
#define sc2(a,b) scanf("%d%d",&a,&b)
#define sc3(a,b,c) scanf("%d%d%d",&a,&b,&c)
#define scl(a) scanf("%lld",&a)
#define scl2(a,b) scanf("%lld%lld",&a,&b)
#define scl3(a,b,c) scanf("%lld%lld%lld",&a,&b,&c)
#define l_b lower_bound
#define u_b upper_bound

#define min_2(a,b) a<b?a:b
#define min_3(a,b,c) min_2(min_2(a,b),c)
#define max_2(a,b) a>b?a:b
#define max_3(a,b,c) max_2(max_2(a,b),c)
#define ll long long
#define rint register int
#define mem0(x) memset(x, 0, sizeof(x))
#define mem1(x) memset(x, -1, sizeof(x))
#define lowbit(x)  x&-x
/**inline int read()///神奇的读优
{
    int x=0,f=1;char c=getchar();
    while(c<'0'||c>'9'){if(c=='-')f=-1;c=getchar();}
    while(c>='0'&&c<='9'){x=x*10+c-'0';c=getchar();}
    return x*f;
}*/
///2147483647 -2147483648
///9223372036854775807 -9223372036854775808
//freopen("input.txt", "r", stdin);
const double PI=acos(-1.0);
const int inf = 0x3f3f3f3f;
const ll inff = 0x3f3f3f3f3f3f3f3f;
const int mod = 1e9+7;
const int maxn= 1e8+5;

//map<ll,ll>mp;
//set<ll>st;
//stack<>st;
//queue<>Q;
/***********************************************/
vector<ll>V;
ll x[200+3],y[200+3];


ll solve(ll a,ll b,ll c,ll d,ll e,ll f)
{
    return abs(a*d+b*e+c*f-a*f-b*c-d*e);
}

int main()
{
    int T;
    cin>>T;
    while(T--)
    {
        V.clear();
        int n,k;
        sc2(n,k);

        for(int i=1;i<=n;i++){
            scanf("%lld%lld",&x[i],&y[i]);
        }

        for(int i=1;i<=n-2;i++)
        {
            for(int j=i+1;j<=n-1;j++){
                for(int p=j+1;p<=n;p++){
                    ll ans=solve(x[i],y[i],x[j],y[j],x[p],y[p]);
                    if(ans) V.push_back(ans);
                }
            }
        }
        int nn=V.size();
        nth_element(V.begin(),V.begin()+nn-k,V.end());
        if(V[nn-k]%2)
        printf("%lld.50\n",V[nn-k]/2);
        else
        printf("%lld.00\n",V[nn-k]/2);
    }
    return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/167088.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • Ubuntu下插入网线无法联网的问题

    Ubuntu下插入网线无法联网的问题今天把以前的服务器搬出来,准备训练一个深度学习模型,然而,在联网的过程中,出现一个问题:就是插入网线后无法联网。想到以前配置过翻墙,就把相关的配置文件如.bashrc,/etc/profile,等相关文件进行了修改,屏蔽掉以前的翻墙代理设置,然而还是无法联网。后面想到以前是用拨号INodeClient来连接上网的,就把与InodeClient相关的配置注释掉,然而还是无法上网。后面在网上找到一个解决方案:参考网址https://blog.csdn.net/zhu334974857/articl.

  • Java并发之AQS详解[通俗易懂]

    Java并发之AQS详解[通俗易懂]今天学了学并发AQS机制,是抽象队列同步器,用户主要通过继承AQS类,来实现自定义锁,从而完成特定功能,AQS提供了两种锁(1)共享锁(2)排他锁。下面这个博客介绍的AQS机制挺不错可以看看原文链接一、概述  谈到并发,不得不谈ReentrantLock;而谈到ReentrantLock,不得不谈AbstractQueuedSynchronizer(AQS)!类如其名,抽象的队列式的同步器,AQS定义了一套多线程访问共享资源的同步器框架,许多同步类实现都依赖于它,如常用的ReentrantLock

  • 面试官:你说熟悉MySQL,那来谈谈InnoDB怎么解决幻读的?

    点击上方“全栈程序员社区”,星标公众号 重磅干货,第一时间送达 作者:Aaron_涛 blog.csdn.net/qq_33330687/article/details/89004…

  • 中国知网爬虫

    中国知网爬虫中国知网爬虫一、知网介绍提起中国知网,如果你曾经写过论文,那么基本上都会与中国知网打交道,因为写一篇论文必然面临着各种查重,当然翟博士除外。但是,本次重点不在于写论文跟查重上,而在于我们要爬取知网上一些论文的数据,什么样的数据呢?我们举一个例子来说,在知网上,搜索论文的方式有很多种,但是对于专业人士来说,一般都会使用高级检索,因为直接去查找作者的话,容易查找到很多重名作者,所以我们本次的爬…

  • 源码网_python源码从哪下载

    源码网_python源码从哪下载源码目录结构我们首先来看下models.py的代码结构我们可以看到这个模块中定义了12个属性和22个模型类,我们依次来看属性源码分析importosfromenumimportEnu

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号