图形面积——竞赛水题

题目描述

 

编程计算由“*”号围成的下列图形的面积。面积计算方法是统计*号所围成的闭合曲线中水平线和垂直线交点的数目。如下图所示,在10*10的二维数组中,有“*”围住了15个点,因此面积为15。

图形面积

输入

输入0-1矩阵(1表示*)

输出

输出面积。

样例输入

0 0 0 0 0 0 0 0 0 0
0 0 0 0 1 1 1 0 0 0
0 0 0 0 1 0 0 1 0 0
0 0 0 0 0 1 0 0 1 0
0 0 1 0 0 0 1 0 1 0
0 1 0 1 0 1 0 0 1 0
0 1 0 0 1 1 0 1 1 0
0 0 1 0 0 0 0 1 0 0
0 0 0 1 1 1 1 1 0 0
0 0 0 0 0 0 0 0 0 0

样例输出

15

解题思路

给图形四周围上一圈由-1;判断每个0的四周(上下左右)是否存在-1,若存在-1,把0变为为-1。最后只要计算0的个数就行了。

如下图

-1-1-1-1-1-1-1-1-1-1-1-1
-1 0 0 0 0 0 0 0 0 0 0-1 
-1 0 0 0 0 1 1 1 0 0 0-1 
-1 0 0 0 0 1 0 0 1 0 0-1 
-1 0 0 0 0 0 1 0 0 1 0-1 
-1 0 0 1 0 0 0 1 0 1 0-1 
-1 0 1 0 1 0 1 0 0 1 0-1 
-1 0 1 0 0 1 1 0 1 1 0-1 
-1 0 0 1 0 0 0 0 1 0 0-1 
-1 0 0 0 1 1 1 1 1 0 0-1 
-1 0 0 0 0 0 0 0 0 0 0-1
-1-1-1-1-1-1-1-1-1-1-1-1


 代码如下:

#include<iostream>
#include<string>
using namespace std;
int pan[12][12];
int main()
{
    int sum=0;
    for(int i=0;i<12;i++)
        for(int j=0;j<12;j++)
        pan[i][j]=0;
    for(int i=0;i<12;i++)
    {
            pan[i][0]=-1;
            pan[0][i]=-1;
            pan[i][11]=-1;
            pan[11][i]=-1;
    }
    for(int i=1;i<11;i++)
        for(int j=1;j<11;j++)
        {
            cin>>pan[i][j];
        }
     
    for(int i=1;i<11;i++)
        for(int j=1;j<11;j++)
        {
            if(pan[i][j]==0&&pan[i-1][j]==-1)
                pan[i][j]=-1;
            if(pan[i][j]==0&&pan[i][j-1]==-1)
                pan[i][j]=-1;
            if(pan[i][j]==0&&pan[i+1][j]==-1)
                pan[i][j]=-1;
            if(pan[i][j]==0&&pan[i][j+1]==-1)
                pan[i][j]=-1;               
        }
    for(int j=1;j<11;j++)
        for(int i=1;i<11;i++)
        {
            if(pan[i][j]==0&&pan[i-1][j]==-1)
                pan[i][j]=-1;
            if(pan[i][j]==0&&pan[i][j-1]==-1)
                pan[i][j]=-1;
            if(pan[i][j]==0&&pan[i+1][j]==-1)
                pan[i][j]=-1;
            if(pan[i][j]==0&&pan[i][j+1]==-1)
                pan[i][j]=-1;               
        }   
    for(int i=1;i<11;i++)
        for(int j=1;j<11;j++)
        {
            if(pan[i][j]==0)
            sum++;
        }
    cout<<sum;        
}

 

  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
《计算机图形学——几何工具算法详解》PDF是一本关于计算机图形学的书籍,主要介绍了图形学中的几何工具算法。 该书详细解析了计算机图形学中的几何工具算法,涵盖了从基础知识到高级算法的内容。首先,书中介绍了计算机图形学的基本概念和原理,包括图形学的历史背景、矢量、二维坐标系和三维坐标系等基础知识。然后,书中详细介绍了几何变换算法,包括平移、旋转、缩放等操作对图形的影响及其在计算机图形学中的应用。此外,还介绍了曲线和曲面的绘制算法,如贝塞尔曲线、B样条曲线和NURBS曲面等,以及相关算法的实现方法。另外,书中还详细阐述了光照和着色算法,包括光照模型、阴影生成和着色技术等。 《计算机图形学——几何工具算法详解》PDF书籍内容丰富、详细,适合计算机图形学领域的学习者和研究者阅读。通过学习该书,读者可以系统地了解计算机图形学的几何工具算法,掌握图形学中的基本概念和实际应用技术。此外,书中还提供了大量的实例和案例,有助于读者将理论知识应用到实际问题解决中。 总之,通过阅读《计算机图形学——几何工具算法详解》PDF,读者可以深入了解计算机图形学的几何工具算法,掌握相关的基本概念和实际应用技术,对计算机图形学领域有更深入的认识和理解。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值