线性分类器【202006-1/CCF】————附带完整代码和思路

0 结果

在这里插入图片描述
难点:如何判断点在直线的那一侧

1 题目

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2 思路

  • 1 把A类的点坐标带入直线方程式(k1+k2X+k3Y)中,如果计算(并记录值的正负)出的值全部大于或者小于(由于点不落在直线上,因此不存在为0的情况),那么执行步骤2,否则,输出No,结束;
  • 2 计算B类的点坐标带入直线方程式(k1+k2X+k3Y)中的值,如果计算出的值的符号和A类点的计算出的符号同号,输出No,结束,否则继续计算;
  • 3 计算完两类点,但是没有输出No,则输出Yes。

3 代码实现

3.1 使用std::vector<std::pair<int,int>>可能会爆编译错误

#include<cstdio>
#include<vector>
#include<utility>

void Judge(const std::vector<std::pair<int, int>>& A, const std::vector<std::pair<int, int>>& B, int var1, int var2, int var3){
    bool firstAssignment = true;
    bool symbol;//zheng--true, fu--false
    for(std::vector<std::pair<int, int>>::const_iterator i = A.begin();i != A.end();i++){
        if(firstAssignment == true){
            firstAssignment = false;
            if(var1 + i->first*var2 + i->second*var3 > 0){
                symbol = true;
            }else{
                symbol = false;
            }
        }else{
            if(var1 + i->first*var2 + i->second*var3 > 0 && symbol == false){
                printf("No");
                return;
            }else if(var1 + i->first*var2 + i->second*var3 < 0 && symbol == true){
                printf("No");
                return;
            }
        }
    }

    for(std::vector<std::pair<int, int>>::const_iterator i = B.begin();i != B.end();i++){
        if(var1 + i->first*var2 + i->second*var3 > 0 && symbol == true){
            printf("No");
            return;
        }else if(var1 + i->first*var2 + i->second*var3 < 0 && symbol == false){
            printf("No");
            return;
        }
    }
    printf("Yes");
}

int main(){
    int n, m;
    std::vector<std::pair<int, int>>A, B;
    scanf("%d%d", &n, &m);
    while(n--){
        int x, y;
        char letter;
        scanf("%d %d %c", &x, &y, &letter);
        std::pair<int, int> tempPoint;
        tempPoint.first = x;
        tempPoint.second = y;
        if(letter == 'A'){
            A.push_back(tempPoint);
        }else{
            B.push_back(tempPoint);
        }
    }
    bool firstLineFeed = true;
    while(m--){
        int var1, var2, var3;
        scanf("%d%d%d", &var1, &var2, &var3);
        if(firstLineFeed == true){
            firstLineFeed = false;
        }else{
            printf("\n");
        }
        Judge(A, B, var1, var2, var3);
    }
    return 0;
}

/*
9 3
1 1 A
1 0 A
1 -1 A
2 2 B
2 3 B
0 1 A
3 1 B
1 3 B
2 0 A
0 2 -3
-3 0 2
-3 1 1
*/

3.2 使用struct代替

#include<cstdio>
#include<vector>
#include<utility>

typedef struct Data{
    int first;
    int second;
}data;

void Judge(const std::vector<data>& A, const std::vector<data>& B, int var1, int var2, int var3){
    bool firstAssignment = true;
    bool symbol;//zheng--true, fu--false
    for(std::vector<data>::const_iterator i = A.begin();i != A.end();i++){
        if(firstAssignment == true){
            firstAssignment = false;
            if(var1 + i->first*var2 + i->second*var3 > 0){
                symbol = true;
            }else{
                symbol = false;
            }
        }else{
            if(var1 + i->first*var2 + i->second*var3 > 0 && symbol == false){
                printf("No");
                return;
            }else if(var1 + i->first*var2 + i->second*var3 < 0 && symbol == true){
                printf("No");
                return;
            }
        }
    }

    for(std::vector<data>::const_iterator i = B.begin();i != B.end();i++){
        if(var1 + i->first*var2 + i->second*var3 > 0 && symbol == true){
            printf("No");
            return;
        }else if(var1 + i->first*var2 + i->second*var3 < 0 && symbol == false){
            printf("No");
            return;
        }
    }
    printf("Yes");
}

int main(){
    int n, m;
    std::vector<data> A, B;
    scanf("%d%d", &n, &m);
    while(n--){
        int x, y;
        char letter;
        scanf("%d %d %c", &x, &y, &letter);
        data tempPoint;
        tempPoint.first = x;
        tempPoint.second = y;
        if(letter == 'A'){
            A.push_back(tempPoint);
        }else{
            B.push_back(tempPoint);
        }
    }
    bool firstLineFeed = true;
    while(m--){
        int var1, var2, var3;
        scanf("%d%d%d", &var1, &var2, &var3);
        if(firstLineFeed == true){
            firstLineFeed = false;
        }else{
            printf("\n");
        }
        Judge(A, B, var1, var2, var3);
    }
    return 0;
}

/*
9 3
1 1 A
1 0 A
1 -1 A
2 2 B
2 3 B
0 1 A
3 1 B
1 3 B
2 0 A
0 2 -3
-3 0 2
-3 1 1
*/

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
资源来源于网络,如有侵权,私信立删。 CSP-J/S第一轮时间 CSP-J/S第一轮分为:CSP-J1和CSP-S1。和NOIP第一轮时间一样,CSP-J/S第一轮认证在10月份第三个星期六进行。 CSP-J/S第一轮考察重点 第一轮认证为笔试或机试,主要测试选手有关计算机方面的基本知识,第一轮为资格测试。从2020年开始,全部为机试。 CSP-J/S第一轮报名方式 参加CSP-S/J两组两轮认证均须在网上注册报名,注册网站为http://rg.noi.cn。参加认证者必须如实填写个人信息报名,包括但不限于姓名、身份证号、出生日期、性别、就学(学籍学校)/就职单位等,信息一旦注册,不得修改,如有错误,责任自负。 CSP-J/S第一轮认证考点 省认证点由CCF授权的CSP非专业级别省认证组织单位设置。 1、第一轮认证点:由省认证组织单位总负责人设置,每个认证点人数不应少于20人。 2、未经批准的认证点,其认证成绩不予承认。 认证费用 第一轮CSP-S/J组:50元/人(该费用不包括食宿及交通费)。 CSP-J/S第一轮认证试题组成 CSP-J/S第一轮在10月份第三个星期六进行,其中CSP-J1认证时间为周六9:30-11:30,CSP-S1认证时间为周六14:30-16:30。考试时长为2小时,内容为笔试或机试(从2020年开始全部为机试),满分100分。 试题由三部分组成: ① 选择题(共15题,每题2分,共计30分) CSP-S1的前10道题为单选题,后10道题为不定项选择题(只有全部选对才得分,否则不得分);CSP-J1的前15道题都是单选题。 ② 程序阅读理解题(共3题,共计40分) 题目给出一段程序(不一定有关于程序功能的说明),考生通过阅读理解该段程序进行答题,分为选择题和判断题。 ③ 程序完善题(共3题,共计30分) 题目给出一段关于程序功能的文字说明,然后给出一段程序代码,在代码中略去了若干个语句或语句的一部分并在这些位置给出空格,要求考生根据程序的功能说明和代码的上下文,选择对应答案 。三题皆为选择题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

繁星蓝雨

如果觉得文章不错可以请喝咖啡

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值