在编写图形界面软件的时候,经常会遇到处理两个矩形的关系。

如图【1.jpg】所示,矩形的交集指的是:两个矩形重叠区的矩形,当然也可能不存在(参看【2.jpg】)。两个矩形的并集指的是:能包含这两个矩形的最小矩形,它一定是存在的。

本题目的要求就是:由用户输入两个矩形的坐标,程序输出它们的交集和并集矩形。

矩形坐标的输入格式是输入两个对角点坐标,注意,不保证是哪个对角,也不保证顺序(你可以体会一下,在桌面上拖动鼠标拉矩形,4个方向都可以的)。

输入数据格式:

x1,y1,x2,y2

x1,y1,x2,y2

数据共两行,每行表示一个矩形。每行是两个点的坐标。x坐标在左,y坐标在右。坐标系统是:屏幕左上角为(0,0),x坐标水平向右增大;y坐标垂直向下增大。

要求程序输出格式:

x1,y1,长度,高度

x1,y1,长度,高度

也是两行数据,分别表示交集和并集。如果交集不存在,则输出“不存在”

前边两项是左上角的坐标。后边是矩形的长度和高度。

例如,用户输入:

100,220,300,100

150,150,300,300

则程序输出:

150,150,150,70

100,100,200,200

例如,用户输入:

10,10,20,20

30,30,40,40

则程序输出:

不存在

10,10,30,30

注意:

请仔细调试!您的程序只有能运行出正确结果的时候才有机会得分!

在评卷时使用的输入数据与试卷中给出的实例数据可能是不同的。

package com.liu.ex6;

import java.util.Scanner;

public class Main {
public static int[][] point = new int[4][2];
public static int[][] result = new int[2][4]; public void getResult(String[] A) {
String[] tempA1 = A[0].split(",");
String[] tempA2 = A[1].split(",");
point[0][0] = Integer.valueOf(tempA1[0]);
point[0][1] = Integer.valueOf(tempA1[1]);
point[1][0] = Integer.valueOf(tempA1[2]);
point[1][1] = Integer.valueOf(tempA1[3]);
point[2][0] = Integer.valueOf(tempA2[0]);
point[2][1] = Integer.valueOf(tempA2[1]);
point[3][0] = Integer.valueOf(tempA2[2]);
point[3][1] = Integer.valueOf(tempA2[3]); //第一个矩形对角线坐标
int x1 = Math.min(point[0][0], point[1][0]);
int y1 = Math.min(point[0][1], point[1][1]);
int x2 = Math.max(point[0][0], point[1][0]);
int y2 = Math.max(point[0][1], point[1][1]);
//第二个矩形对角线坐标
int x3 = Math.min(point[2][0], point[3][0]);
int y3 = Math.min(point[2][1], point[3][1]);
int x4 = Math.max(point[2][0], point[3][0]);
int y4 = Math.max(point[2][1], point[3][1]);
if(x3 >= x2 || x1 >= x4 || y3 >= y2 || y1 >= y4) {
result[0][0] = -1; //表示交集不存在
} else {
int x = 0, y = 0, len = 0, high = 0;
if(x3 >=x1 && x3 < x2) {
if(x4 >= x2) {
x = x3;
len = x2 - x3;
} else {
x = x3;
len = x4 - x3;
}
} else if(x1 >= x3 && x1 < x4) {
if(x2 >= x4) {
x = x1;
len = x4 - x1;
} else {
x = x1;
len = x2 - x1;
}
} if(y3 >= y1 && y3 < y2) {
if(y4 >= y2) {
y = y3;
high = y2 - y3;
} else {
y = y3;
high = y4 - y3;
}
} else if(y1 >= y3 && y1 < y4) {
if(y2 >= y4) {
y = y1;
high = y4 - y1;
} else {
y = y1;
high = y2 - y1;
}
} result[0][0] = x;
result[0][1] = y;
result[0][2] = len;
result[0][3] = high;
} int x = Math.min(x1, x3);
int y = Math.min(y1, y3);
int len = Math.max(x2, x4) - x;
int high = Math.max(y2, y4) - y;
result[1][0] = x;
result[1][1] = y;
result[1][2] = len;
result[1][3] = high;
} public static void main(String[] args) {
Main test = new Main();
Scanner in = new Scanner(System.in);
String[] A = new String[2];
for(int i = 0;i < 2;i++) {
A[i] = in.next();
}
test.getResult(A);
for(int i = 0;i < 2;i++) {
for(int j = 0;j < 3;j++) {
if(i == 0 && result[0][0] == -1) {
System.out.println("不存在");
break;
} else {
System.out.print(result[i][j]+",");
}
}
if(result[0][0] != -1)
System.out.println(result[i][3]);
else {
if(i == 1)
System.out.println(result[i][3]);
}
}
}
}

java实现矩形区域的交和并的更多相关文章

  1. Java实现 LeetCode 363 矩形区域不超过 K 的最大数值和

    363. 矩形区域不超过 K 的最大数值和 给定一个非空二维矩阵 matrix 和一个整数 k,找到这个矩阵内部不大于 k 的最大矩形和. 示例: 输入: matrix = [[1,0,1],[0,- ...

  2. BC 2015在百度之星程序设计大赛 - 预赛(1)(矩形区域-旋转卡)

    矩形区域 Accepts: 717 Submissions: 1619 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 ...

  3. 玩转Android Camera开发(四):预览界面四周暗中间亮,仅仅拍摄矩形区域图片(附完整源代码)

    杂家前文曾写过一篇关于仅仅拍摄特定区域图片的demo.仅仅是比較简陋.在坐标的换算上不是非常严谨,并且没有完毕预览界面四周暗中间亮的效果,深以为憾.今天把这个补齐了. 在上代码之前首先交代下,这里面存 ...

  4. LeetCode:矩形区域【223】

    LeetCode:矩形区域[223] 题目描述 在二维平面上计算出两个由直线构成的矩形重叠后形成的总面积. 每个矩形由其左下顶点和右上顶点坐标表示,如图所示. 示例: 输入: -3, 0, 3, 4, ...

  5. Leetcode 363.矩形区域不超过k的最大数值和

    矩形区域不超过k的最大数值和 给定一个非空二维矩阵 matrix 和一个整数 k,找到这个矩阵内部不大于 k 的最大矩形和. 示例: 输入: matrix = [[1,0,1],[0,-2,3]], ...

  6. opencv2 使用鼠标绘制矩形并截取和保存矩形区域图像

    前言 好长时间没写博文了,今天偷偷懒写篇关于opencv2中鼠标响应操作的文章. 鼠标操作属于用户接口设计,以前一直使用Qt来做,但是如果只需要简单的鼠标,键盘操作,直接调用opencv库的函数也未尝 ...

  7. 【代码笔记】iOS-根据size截取屏幕中间矩形区域

    代码: RootViewController.m #import "RootViewController.h" @interface RootViewController () @ ...

  8. Win32 GDI 非矩形区域剪裁,双缓冲技术

    传统的Win32通过GDI提供图形显示的功能,包括了基本的绘图功能,如画线.方块.椭圆等等,高级功能包括了多边形和Bezier的绘制.这样app就不用关心那些图形学的细节了,有点类似于UNIX上的X- ...

  9. 在OpenCV中利用鼠标绘制矩形和截取图像的矩形区域

    这是两个相关的程序,前者是后者的基础.实际上前一个程序也是在前面博文的基础上做的修改,请参考<在OpenCV中利用鼠标绘制直线> .下面贴出代码. 程序之一,在OpenCV中利用鼠标绘制矩 ...

随机推荐

  1. flink基础篇

    Flink面试--核心概念和基础考察 1.简单介绍一下 Flink 2.Flink 相比传统的 Spark Streaming 有什么区别? 3.Flink 的组件栈有哪些?         面试知识 ...

  2. [Unity UGUI图集系统]浅谈UGUI图集使用

    **写在前面,下面是自己做Demo的时候一些记录吧,参考了很多网上分享的资源 一.打图集 1.准备好素材(建议最好是根据图集名称按文件夹分开) 2.创建一个SpriteAtlas 3.将素材添加到图集 ...

  3. C# 数据操作系列 - 14 深入探索SqlSugar

    0.前言 在上一篇中,我们知道了如何使用SqlSugar,但是也只是简单的了解了如何使用,仿佛是套着镣铐行走,这明显不符合一个合格的程序员应有的素养.所以,这一篇我们将对其进行深挖,探究其背后的秘密. ...

  4. .Net基础之4——流程控制

    (1)异常捕获 我们在程序中经常会出现各种各样的异常,你如果想要你的程序变得坚强一点. 在你的代码中应该经常性的使用try-catch来进行异常捕获. 语法: try { 可能会出现异常的代码: } ...

  5. Vue 更换页面图标和title

    1.基础的做法就是直接换掉,logo换的时候需要使用icon格式的图标 title 直接在index.html 里面把原来的title注释掉 或者直接改了就行 2. 如果需要进行相应的改变啥的 ,需要 ...

  6. MySQL复制表结构以及复制表等等

    mysql中用命令行复制表结构的方法主要有一下几种: 1.只复制表结构到新表 1 CREATE TABLE 新表 SELECT * FROM 旧表 WHERE 1=2; 或 1 CREATE TABL ...

  7. 【java】关键字volatile

    volatile 1. 含义: volatile是JVM提供的轻量级的同步机制,具有三个特点:保证可见性.不保证原子性.禁止指令重排. 1.1 保证可见性 一个线程修改了共享变量并写回主内存,其他线程 ...

  8. CF1340B Nastya and Scoreboard(暴搜剪枝/dp)

    Question 一个n个数码位的分数板,每一个数码位都是一个七段数码管,现在给出每个数码位的显示情况,问再点亮k段数码管的话能显示的最大的数是多少,如果不能构成一串数字,就输出-1 Solution ...

  9. [wordpress使用]001_环境安装

    Wordpress强大的可扩展性和易用性等功能,使得越来越多的人选择它来建立自己的博客和网站.那么新手朋友该如何入手呢,今天制作这个教程就是旨在帮助新手朋友快速入门,从而为今后WP建站打下坚实的基础. ...

  10. Java IO(十三)PipedReader 和 PipedWriter

    Java IO(十三)PipedReader 和 PipedWriter 一.介绍 PipedReader 和 PipedWriter 分别是管道字符输入流和管道字符输出流,它们同 PipedInpu ...