统计方形(暴力枚举)

洛谷P2241-统计方形

题目描述:

有一个 n×m 方格的棋盘,求其方格包含多少正方形、长方形(不包含正方形)。

java 复制代码
import java.util.*;
public class Main {
    public static void main(String[] args) {
		Scanner in=new Scanner(System.in);
		int n=in.nextInt();
		int m=in.nextInt();
		int sum=0,square=0;
		for(int i=1;i<=n;i++)
			for(int j=1;j<=m;j++){
				//sum为所有矩形总数
				sum += i * j;
				//square为正方形个数
				square += i < j ? i : j;	
			}
		//输出正方形数 和 矩形数(不包括正方形)
		System.out.println(square+" "+(sum-square));
	   
    }
}

测试用例:输入:2 3 输出:8 10


思路:

所有方形的个数=正方形的个数+长方形的个数。对于任意一个n行m列的矩形,以这个方形右下角的那个块作为要在矩形内选择正方形或长方形的右下角,则正方形的个数为min(i,j),长方形的个数为i∗j

解释如下:

对于一个n行m列的矩形,右下角的块必选,则能和这个块组成的正方形的右上角块全在这个主对角线上,而对角线上块的数量就是min(i,j)。对于矩形来说,n行m列的矩形内所有点都能和右下角的这个点构成长方形,所以长方形的数量就是i*j。

相关推荐
6***v4178 分钟前
搭建Golang gRPC环境:protoc、protoc-gen-go 和 protoc-gen-go-grpc 工具安装教程
开发语言·后端·golang
1***s6329 分钟前
Rust在WebAssembly中的应用实践
开发语言·rust·wasm
水痕0110 分钟前
go使用cobra来启动项目
开发语言·后端·golang
雨中飘荡的记忆22 分钟前
深入理解设计模式之单例模式
java·设计模式
scixing26 分钟前
函数式编程 第八讲 循环者,递归也
开发语言·c#
程序员西西30 分钟前
Spring Boot整合MyBatis调用存储过程?
java·后端
2501_9418798141 分钟前
Python在微服务高并发异步API网关请求处理与智能路由架构中的实践
java·开发语言
AAA简单玩转程序设计43 分钟前
Java进阶小白手册:基础玩法升级,告别青铜套路
java
whltaoin44 分钟前
【 手撕Java源码专栏 】Spirng篇之手撕SpringBean:(包含Bean扫描、注册、实例化、获取)
java·后端·spring·bean生命周期·手撕源码
闻缺陷则喜何志丹1 小时前
【SOSDP模板 容斥原理 逆向思考】3757. 有效子序列的数量|分数未知
c++·算法·力扣·容斥原理·sosdp·逆向思考