现在的位置: 首页 > 综合 > 正文

图形点扫描

2013年09月13日 ⁄ 综合 ⁄ 共 2074字 ⁄ 字号 评论关闭

1.问题描述

 

   有一条“封闭”曲线划定的地图,界定曲线上的点有“1“表示,曲线内外的点用“0”表示(具体数据由另文件提供)。

   试实施图形点扫描,统计地图的面积即“封闭”曲线内“0”点数。

 

2.设计思路

 

   要统计用“1”标识的标识的封闭曲线内“0”点的点数,关键在于如何识别哪些“0”点在封闭曲线内,哪些“0”点在封闭曲线外。

   试对封闭曲线外的“0”点实施“扩散传染”处理,处理成“2”点,以与曲线的“0”点相区别。考虑到连续曲线可能复杂的弯曲变化,用简单一次穷举难以区分曲线内与外的“0”,可把曲线外的“0”通过金疮“扩散传染”逐个变为“2”,因封闭曲线隔离使得曲线内的“0”保持不变。

 

   1.四周边上的“0”无疑在曲线外,变为“2”。

   2.凡与“2”相邻的“0”点通过“传染”变为“2”。即判断每一个“0”点,若它的上下左右元素中有某一个为“2”点,即被扩散传染为“2”。

   3.约定扫描x*y(即图中点的个数)次。设置变量flag,每次扫描前,flag=0;凡有扩散传染发生,flag=1。每次扫描后检验,如果flag=0,表示该次扫描没有传染发生,即停止。

   4.统计“0”的点数即为所求封闭曲线的面积。

 

3.代码实现

 

 

参考文献:《趣味C程序设计》

抱歉!评论已关闭.