原题链接:电导流的矩形
解题思路:对于两个不确定位置的对角坐标,用max,min函数确定左右(上下)边界,用abs函数确定其长度与宽度;
注意事项:注意不同数组所代表的含义;
参考代码:
#include <iostream> #include <cmath> #include <cstring> #include <algorithm> using namespace std; int main() { int n,arr[20][5],x,y,lenth[20],wide[20],s[20],ss[20],flags[20]; cin>>n; memset(flags,0,sizeof(flags));//默认标记为0(电针不在矩阵内),若在,重新标记即可 memset(s,0,sizeof(s)); //面积初始化为0,满足条件的重新赋值即可,保留下标和对应面积值 memset(ss,0,sizeof(ss)); //用于找出满足条件的最大面积,会打乱下标 for(int i=1;i<=n;i++) { for(int j=1;j<=4;j++)//列标j代表4个数据 { cin>>arr[i][j];//行标i表示第几个矩形 } } cin>>x>>y;//输入电针坐标 for(int i=1;i<=n;i++) { if(x>=min(arr[i][3],arr[i][1])&&x<=max(arr[i][3],arr[i][1]))//横坐标在矩形范围内(小的在左边,大的在右边) if(y>=min(arr[i][4],arr[i][2])&&y<=max(arr[i][4],arr[i][2]))//纵坐标在矩形范围内(小的在下边,大的在上边) flags[i]=1;//电针在矩形范围内标记为1 } for(int i=1;i<=n;i++) { if(flags[i]==1)//对于包含电针的矩形求其面积,并赋值给另一数组ss,用于排序 { lenth[i]=abs(arr[i][3]-arr[i][1]);//注意用绝对值函数,因为不确定哪个坐标大 wide[i]=abs(arr[i][4]-arr[i][2]); s[i]=wide[i]*lenth[i]; ss[i]=s[i]; } } sort(ss+1,ss+n+1);//对满足条件的面积进行排序 (数组首地址从第0个开始,我写的是从1开始(保证对应行标),故加1),最后一个元素ss[n]为最大值 for(int i=1;i<=n;i++)//从第一个开始判断,以保证编号尽可能小 { if(flags[i]==1&&s[i]==ss[n])//电针在矩形范围内,且为最大面积 { cout<<i;//输出行标,即第几个矩形 return 0; } } return 0; }
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复