zoukankan      html  css  js  c++  java
  • Java练习 SDUT-2401最大矩形面积

    最大矩形面积

    Time Limit: 1000 ms Memory Limit: 65536 KiB

    Problem Description

    在一个矩形区域内有很多点,每个点的坐标都是整数。求一个矩形,使之内部没有点,且面积最大。所求矩形的边与坐标轴平行。

    Input

    一个整数t,表示测试组数。
    整数l,w表示矩形横向边长和竖向边长。
    一个整数n,表示该矩形内点的个数。
    n个点的坐标x,y。

    Output

    最大面积。

    Sample Input

    2
    2 3
    0
    10 10
    4
    1 1
    9 1
    1 9
    9 9

    Sample Output

    6
    80

    题解:这道题是一道偏向思维的题目,先让点从左往右跑一边然后从上往下跑一边找出最大的矩形面积。注意边界的更新,需要让这个点再边界内部,一开始 我想的是根据面积最小的损失来更新这个点,结果后来意识到,比如一个点的x坐标7,此时的左右边界的值跟新为(0,6),这个点就不再范围内了,这样就导致该点不再所求的矩形的边上,然而循环求的意义在于求与这个点有关的矩形的面积(点在矩形边上)。

    import java.util.*;
    
    public class Main {
    	public static void main(String []args)
    	{
    		Scanner cin = new Scanner(System.in);
    		int t,i,lr,ud;
    		node a = new node();
    		t = cin.nextInt();
    		while(t-->0)
    		{
    			a.l = cin.nextInt();
    			a.w = cin.nextInt();
    			a.n = cin.nextInt();
    			a.INIT();
    			//System.out.println(a.n);
    			for(i=2;i<a.n;i++)
    			{
    				a.s[i].x = cin.nextInt();
    				a.s[i].y = cin.nextInt();
    			}
    			lr = a.get_lr();
    			ud = a.get_ud();
    			System.out.println(Math.max(lr, ud));
    		}
    		cin.close();
    	}
    }
    
    class point
    {
    	int x,y;
    }
    /*具体的解题代码*/
    class node
    {
    	int l,w,n;
    	point s[] = new point[1050];
    	/*初始化,让边界成为一个点(最大的矩形面积)*/
    	void INIT()
    	{
    		int i;
    		n = n + 2;
    		for(i=0;i<n;i++)
    			s[i] = new point();
    		s[0].x = 0;
    		s[0].y = 0;
    		s[1].x = l;
    		s[1].y = w;
    	}
    	/*根据x的大小对点进行排序*/
    	void sortlr()
    	{
    		int i,j;
    		point t = new point();
    		for(i=0;i<n;i++)
    		{
    			for(j=0;j<n-i-1;j++)
    			{
    				if(s[j].x>s[j+1].x)
    				{
    					t = s[j];
    					s[j] = s[j+1];
    					s[j+1] = t;
    				}
    				else if(s[j].x==s[j+1].x)
    				{
    					if(s[j].y>s[j+1].y)
    					{
    						t = s[j];
    						s[j] = s[j+1];
    						s[j+1] = t;
    					}
    				}
    			}
    		}
    	}
    	/*根据y的大小对点进行排序*/
    	void sortud()
    	{
    		int i,j;
    		point t = new point();
    		for(i=0;i<n;i++)
    		{
    			for(j=0;j<n-i-1;j++)
    			{
    				if(s[j].y>s[j+1].y)
    				{
    					t = s[j];
    					s[j] = s[j+1];
    					s[j+1] = t;
    				}
    				else if(s[j].y==s[j+1].y)
    				{
    					if(s[j].x>s[j+1].x)
    					{
    						t = s[j];
    						s[j] = s[j+1];
    						s[j+1] = t;
    					}
    				}
    			}
    		}
    	}
    	/*从左往右寻找最大的矩形面积*/
    	int get_lr()
    	{
    		int ans = 0,i,j,du,dd;
    		sortlr();
    		for(i=0;i<n-1;i++)
    		{
    			du = w;
    			dd = 0;
    			for(j=i+1;j<n;j++)
    			{
    				if(s[i].x!=s[j].x)
    				{
    					ans = Math.max(ans, (s[j].x-s[i].x)*(du-dd));
    					/*更新上下边界,注意让此时的点在边界范围内(即该点在矩形的边上)*/
    					if(s[j].y>s[i].y)
    						du = Math.min(du, s[j].y);
    					else
    						dd = Math.max(dd,s[j].y);
    				}
    			}
    		}
    		return ans;
    	}
    	/*从下往上找最大的矩形面积*/
    	int get_ud()
    	{
    		int ans = 0,i,j,dl,dr;
    		sortud();
    		for(i=0;i<n-1;i++)
    		{
    			dl = 0;
    			dr = l;
    			for(j=i+1;j<n;j++)
    			{
    				if(s[i].y!=s[j].y)
    				{
    					ans = Math.max(ans, (s[j].y-s[i].y)*(dr-dl));
    					/*更新上下边界*/
    					if(s[j].x>s[i].x)
    						dr = Math.min(dr, s[j].x);
    					else
    						dl = Math.max(dl, s[j].x);
    				}
    			}
    		}
    		return ans;
    	}
    }
    
  • 相关阅读:
    StringBuffer
    判断java标识符
    基本数据类型和String相互转换
    使用String
    Properties属性文件
    Map排序
    java集合之三映射:HashMap、Hashtable、LinkedHashMap、TreeMap
    列表、集合与数组之间相互转换
    自定义列表排序
    ML-支持向量:SVM、SVC、SVR、SMO原理推导及实现
  • 原文地址:https://www.cnblogs.com/luoxiaoyi/p/9870238.html
Copyright © 2011-2022 走看看