首页 > 其他 > 详细

UVa 740 - Baudot Data Communication Code

时间:2014-10-15 17:46:02      阅读:235      评论:0      收藏:0      [点我收藏+]

题目:现有一种编码,他们在shift键处于按下和升起时,对应两种编码,其中有2个编码对应shift操作。

              给你对应的编码值,求其对应的字符串。

分析:模拟,字符串。简单题,标记shift的升降分类处理即可。

说明:数据量较小,直接扫描查询即可。

#include <iostream>
#include <cstdlib>
#include <string>
#include <cstdio>

using namespace std;

#define down 1
#define up   0

string ushift,dshift,buf;

int code(int space)
{
	int value = 0;
	for (int i = 0 ; i < 5 ; ++ i) {
		value <<= 1;
		value += buf[space+i]-'0';
	}
	return value;
}

int main()
{
	getline(cin, dshift);
	getline(cin, ushift);
	while (getline(cin, buf)) {
		int state = down;
		for (int i = 0 ; i < buf.length() ; i += 5) {
			int value = code(i);
			if (value == 27) {
				state = down;
			}else if (value == 31) {
				state = up;
			}else if (state == down)
				cout << dshift[value];
			else cout << ushift[value];
		}
		cout << endl;
	}
	return 0;
}

UVa 740 - Baudot Data Communication Code

原文:http://blog.csdn.net/mobius_strip/article/details/40112565

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