首页 > 其他 > 详细

UVa 10878 磁带解码

时间:2014-01-27 19:49:53      阅读:401      评论:0      收藏:0      [点我收藏+]

/*

* 解题思路:

* 此题就是简单的二进制码翻译成字符的题,转换一下即可。

* 注意:得到的字符串不用写换行符、因为得到的字符串中最后一位即为换行符!

*/

#include <stdio.h>
#include <math.h>
int main( )
{
    int p,q,sum;
    int i;
    char ss[ 10000 ];
    char  s[ 10000 ];
    char c;

    p = q = 0;
    while( getchar( )!=‘\n‘ );
    while( ( c=getchar( ) ) != ‘_‘ )
    {
        c = getchar( );
        p = 0;
        while( ( c = getchar( )) !=‘|‘ && c!=‘\n‘ && c!=EOF )
            ss[ p++ ] = c;
        getchar( );

        sum = 0;
        for( i=7;i>=0;i-- )
            if( !(i-4) ) continue;
            else if( ss[ i ] == ‘o‘ && i>4 )
                sum += pow( 2 , 7-i );
            else if( ss[ i ] ==‘o‘ && i<4 )
                sum += pow( 2 , 7-i-1);
        s[ q++ ] = (char)( sum );
    }
    for( i=0;i<q;i++)
        printf("%c",s[ i ] );
    return 0;
}


UVa 10878 磁带解码

原文:http://blog.csdn.net/u011886588/article/details/18814305

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!