ASCII Area

该博客主要介绍了如何计算由字符'/'、''和'.'组成的ASCII矩阵中斜线围成的面积。每组输入包含矩阵的行数h、列数w及字符矩阵,通过分析每个字符确定面积,首个'/'或''后的'.'面积为1,偶数个斜线后的'.'面积为0,斜线自身面积为0.5。程序通过自定义mygetchar()函数实现字符流处理,避免存储矩阵,确保计算精度。
摘要由CSDN通过智能技术生成

问题链接UVALive5910 UVA1641 POJ4022 ASCII Area

题意简述:输入一个字符矩阵,矩阵元素由字符"/"、"\"和"."组成,计算由斜线围成的面积。测试数据有多组,每组首先输入矩阵的行h和列w,然后输入m*n的矩阵。计算面积输出。

问题分析:对于每一行,首个"/"或"\"之后的".",其面积为1;偶数个"/"或"\"之后的"."其面积为0。对于"/"或"\",其面积为0.5。

程序说明:用字符流实现时,封装了函数mygetchar(),使得程序不需要存储矩阵,可以节省存储空间。另外,为了保证计算精度不丢失,使用整数变量来统计面积,最后再做浮点运算。

/* UVALive5910 UVA1641 POJ4022 ASCII Area */  
  
#include <stdio.h>  
#include <ctype.h>  
  
char mygetchar()  
{  
    char c;  
  
    c = getchar();  
    while(c == '\n')  
        c = getchar();  
  
    return c;  
}  
  
int main(void)  
{  
    int h, w, sum, flag, i, j;  
    char c;  
  
    while(scanf("%d%d", &h, &w) != EOF) {  
        sum = 0;  
  
        for(i=1; i<=h; i++) {  
            flag = 0;  
            for(j=1; j<=w; j++) {  
                c = mygetchar();  
                if(c == '/' || c == '\\') {  
                    sum += 1;  
                    flag = 1 - flag;  
                } else if(c == '.' && flag)  
                    sum += 2;  
            }  
        }  
  
        printf("%.0lf\n", (double)sum / 2);  
    }  
  
    return 0;  
}  


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值