博客
关于我
紫书 例题 10-28 UVa 1393(简化问题)
阅读量:681 次
发布时间:2019-03-17

本文共 1119 字,大约阅读时间需要 3 分钟。

如何优化给定的文字:


问题分析与解决思路

这道题目具有对称特性,因此只需计算特定边界条件下的数目,并将结果乘以2即可。

1.1 包围盒分析

每一条直线可以看作一个包围盒,需要枚举包围盒的长宽。分析时需注意以下两种情况:

1.2 情况分析

(1)包围盒内部存在其他包围盒。这种情况下,只有在包围盒交点处且包围盒对角线不重合的情况下,需要单独计算。通过计算gcd值来判断是否为唯一交点。

(2)特殊情况处理:对角线落在一条直线上时,需要减去重复计数的数目。这时数目计算公式为:max(0, m - 2a) * max(0, n - 2b)最终数目为:(m - a) * (n - b) - max(0, m - 2a) * max(0, n - 2b)

1.3 代码实现

为了加快计算,提前预先计算所有gcd值并存储。通过预计算降低重复调用gcd函数的开销。主要代码实现步骤如下:

#include 
#include
#define REP(i, a, b) for(int i = (a); i < (b); i++)using namespace std;const int MAXN = 312;int g[MAXN][MAXN];int gcd(int a, int b) { return !b ? a : gcd(b, a % b);}int main() { REP(i, 1, MAXN) REP(j, 1, MAXN) g[i][j] = gcd(i, j); while (scanf("%d%d", &n, &m) && n) { int ans = 0; REP(a, 1, m + 1) REP(b, 1, n + 1) { if (g[a][b] == 1) { int c = max(0, m - 2*a) * max(0, n - 2*b); ans += (m - a) * (n - b) - c; } } printf("%d\n", ans * 2); } return 0;}

1.4 优化思路

  • 预计算gcd值,提升后续计算效率。
  • 避免重复计算,减少计算量。
  • 处理特殊边界条件,防止数目重复计数。

本文提供的代码实现高效地解决了问题,适用于大范围数据计算。

转载地址:http://oyyhz.baihongyu.com/

你可能感兴趣的文章
Openlayers实战:绘制多边形,导出CSV文件
查看>>
Openlayers实战:绘制带箭头的线
查看>>
Openlayers实战:绘制点、线、圆、多边形
查看>>
Openlayers实战:绘制矩形,正方形,正六边形
查看>>
Openlayers实战:自定义放大缩小,显示zoom等级
查看>>
Openlayers实战:自定义版权属性信息
查看>>
Openlayers实战:输入WKT数据,输出GML、Polyline、GeoJSON格式数据
查看>>
Openlayers实战:选择feature,列表滑动,定位到相应的列表位置
查看>>
Openlayers实战:非4326,3857的投影
查看>>
Openlayers高级交互(1/20): 控制功能综合展示(版权、坐标显示、放缩、比例尺、测量等)
查看>>
Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
查看>>
Openlayers高级交互(11/20):显示带箭头的线段轨迹,箭头居中
查看>>
Openlayers高级交互(12/20):利用高德逆地理编码,点击位置,显示坐标和地址
查看>>
Openlayers高级交互(13/20):选择左右两部分的地图内容,横向卷帘
查看>>
Openlayers高级交互(14/20):汽车移动轨迹动画(开始、暂停、结束)
查看>>
Openlayers高级交互(15/20):显示海量多边形,10ms加载完成
查看>>
Openlayers高级交互(16/20):两个多边形的交集、差集、并集处理
查看>>
Openlayers高级交互(17/20):通过坐标显示多边形,计算出最大幅宽
查看>>
Openlayers高级交互(18/20):根据feature,将图形适配到最可视化窗口
查看>>
Openlayers高级交互(19/20): 地图上点击某处,列表中显示对应位置
查看>>