struggle_wei 2024-05-15 22:43 采纳率: 0%
浏览 5

Transmitters

img

img


#include<stdio.h>
#include<math.h>
float mul(int x1,int y1,int x2,int y2,int x3,int y3)
{
    float k;
    k=(x1*y2-x2*y1+x2*y3-x3*y2+x3*y1-x1*y3)/2.0;
    return k;
}
int dis(int x0,int y0,int x1,int y1)
{
    int m=(x0-x1)*(x0-x1)+(y0-y1)*(y0-y1);
    return m;
}
int main()
{
    int x0,y0,n,i,j,count;
    double R;
    while(scanf("%d%d%lf",&x0,&y0,&R),R>0)
    {
        scanf("%d",&n);
        int a[150][2];
        int b[150];
        for(i=0;i<n;i++)
        for(j=0;j<2;j++)
        scanf("%d",&a[i][j]);
        for(i=0;i<n;i++)
        {
            count=0;
            if(dis(x0,y0,a[i][0],a[i][1])>R*R)
            {
                b[i]=count;
                break;
            }
            else
            {
            for(j=0;j<n;j++)
            {
                
                    float l=mul(x0,y0,a[i][0],a[i][1],a[j][0],a[j][1]);
                    int d=dis(x0,y0,a[j][0],a[j][1]);
                    if(l<=0&&d<=R*R)
                    count++;
            }
            b[i]=count;
          }
            
        }
        int max=b[0];
        for(i=0;i<n;i++)        
        {
            if(b[i]>max)
            max=b[i];
        }
        printf("%d\n",max);
    }
    return 0;
}

错误点在哪里呀,求答案

  • 写回答

2条回答 默认 最新

  • 专家-赤兔[在线] 全栈领域优质创作者 2024-05-15 22:43
    关注

    定义一个函数,计算两个向量点乘并返回结果。

    以上回复有部分引自免费微信小程序:皆我百晓生。 如问题尚未解决,还请稍待,如有疑问请回复进一步沟通。

    评论

报告相同问题?

问题事件

  • 创建了问题 5月15日

悬赏问题

  • ¥20 c语言写的8051单片机存储器mt29的模块程序
  • ¥60 求直线方程 使平面上n个点在直线同侧并且距离总和最小
  • ¥50 java算法,给定试题的难度数量(简单,普通,困难),和试题类型数量(单选,多选,判断),以及题库中各种类型的题有多少道,求能否随机抽题。
  • ¥50 rk3588板端推理
  • ¥250 opencv怎么去掉 数字0中间的斜杠。
  • ¥15 这种情况的伯德图和奈奎斯特曲线怎么分析?
  • ¥250 paddleocr带斜线的0很容易识别成9
  • ¥15 电子档案元素采集(tiff及PDF扫描图片)
  • ¥15 flink-sql-connector-rabbitmq使用
  • ¥15 zynq7015,PCIE读写延时偏大