统计方形(暴力枚举)

洛谷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。

相关推荐
weixin_462446233 分钟前
PaddleX 3.2 人脸识别实战:自定义人脸库 + CartoonFace 官方案例 Top-K 识别完整指南
开发语言·r语言
We་ct8 分钟前
LeetCode 15. 三数之和:排序+双指针解法全解析
前端·算法·leetcode·typescript
挽天java12 分钟前
数据结构习题--寻找旋转排序数组中的最小值
数据结构·算法·排序算法
Testopia20 分钟前
走一遍 AI 学习之路 —— AI实例系列说明
开发语言·人工智能·python
码农娟20 分钟前
Hutool XML工具-XmlUtil的使用
xml·java
你怎么知道我是队长21 分钟前
C语言---排序算法4---希尔排序法
c语言·算法·排序算法
Tony Bai22 分钟前
【分布式系统】11 理论的试金石:用 Go 从零实现一个迷你 Raft 共识
开发语言·后端·golang
Beginner x_u22 分钟前
JavaScript 原型、原型链与原型继承的核心机制解析
开发语言·javascript·原型模式·原型原型链
离离茶22 分钟前
【笔记1-11】Qt 关闭QToolbar的拓展菜单
开发语言·笔记·qt
曹牧25 分钟前
C#:窗体构造函数无法引用窗体控件
开发语言·c#