算法思路:
1、一个直观的思路是筛除法,即:答案=总数-三点共线的种数
总数易求得,为组合数C((n+1)*(m+1),3),考虑到n、m数值范围,考虑用long long。
2、三点共线的情况有:
(1)网格顶点同行,每行有m+1个顶点,共n+1行,共有:C(m+1,3) * (n+1)
(2)网格顶点同列,每列有n+1个顶点,共m+1列,共有:C(n+1,3) * (m+1)
(3)网格顶点同在斜线上,分斜向上和斜向下,显然两者方案数是一样的,下面考虑斜向下情况:
例如:n=5 m=7
(1)以行数为X、列数为Y的二维平面表示方格网络n*m,左上方格顶点为原点(0,0)。
(2)尝试从某网格顶点A朝斜向下方向的点B连斜线