杭电hdu 1332 LC-Display 简单题

http://acm.hdu.edu.cn/showproblem.php?pid=1332

模拟,需要注意的地方:每组数据后有一个空行,每两个数字之间有一个空格。

#include <stdio.h>

int n, s;

void print(char *str, int len)
{
	int i, j, k;
	//head
	for(i = len-1; i >= 0; i --){
		switch(str[i]){
		case '0':
		case '2':
		case '3':
		case '5':
		case '6':
		case '7':
		case '8':
		case '9':
			printf(" ");
			for(j = 0; j < s; j ++){
				printf("-");
			}
			printf(" ");
			break;
		case '1':
		case '4':
			for(j = 0; j < s+2; j ++){
				printf(" ");
			}
			break;
		}
		if(i!=0)printf(" ");
	}
	printf("\n");

	//top body
	for(i = 0; i < s; i ++){
		for(j = len-1; j >= 0; j --){
			switch(str[j]){
			case '1':
			case '2':
			case '3':
			case '7':
				for(k = 0; k < s+1; k ++){
					printf(" ");
				}
				printf("|");
				break;
			case '5':
			case '6':
				printf("|");
				for(k = 0; k < s+1; k ++){
					printf(" ");
				}
				break;
			case '0':
			case '4':
			case '8':
			case '9':
				printf("|");
				for(k = 0; k < s; k ++){
					printf(" ");
				}
				printf("|");
				break;
			}//switch
			if(j!=0)printf(" ");
		}//for
		
		printf("\n");
	}//for

	//middle
	for(i = len-1; i >= 0; i --){
		switch(str[i]){
		case '2':
		case '3':
		case '4':
		case '5':
		case '6':
		case '8':
		case '9':
			printf(" ");
			for(j = 0; j < s; j ++){
				printf("-");
			}
			printf(" ");
			break;
		case '0':
		case '1':
		case '7':
			for(j = 0; j < s+2; j ++){
				printf(" ");
			}
			break;
		}
		if(i!=0)printf(" ");
	}
	printf("\n");

	//low body
	for(i = 0; i < s; i ++){
		for(j = len-1; j >= 0; j --){
			switch(str[j]){
			case '1':
			case '3':
			case '4':
			case '5':
			case '7':
			case '9':
				for(k = 0; k < s+1; k ++){
					printf(" ");
				}
				printf("|");
				break;
			case '2':
				printf("|");
				for(k = 0; k < s+1; k ++){
					printf(" ");
				}
				break;
			case '0':
			case '6':
			case '8':
				printf("|");
				for(k = 0; k < s; k ++){
					printf(" ");
				}
				printf("|");
				break;
			}//switch
			if(j!=0)printf(" ");
		}//for
		printf("\n");
	}//for

	//buttom
	for(i = len-1; i >= 0; i --){
		switch(str[i]){
		case '0':
		case '2':
		case '3':
		case '5':
		case '6':
		case '8':
		case '9':
			printf(" ");
			for(j = 0; j < s; j ++){
				printf("-");
			}
			printf(" ");
			break;
		case '1':
		case '4':
		case '7':
			for(j = 0; j < s+2; j ++){
				printf(" ");
			}
			break;
		}
		if(i!=0)printf(" ");
	}
	printf("\n\n");
}

int main()
{
//	freopen("input.txt","r",stdin);
//	freopen("output.txt","w+",stdout);
	char str[9];
	int len;
	while(scanf("%d%d", &s, &n)){
		if(n==0&&s==0)break;
		len = 0;
		if(n == 0)
			str[len++] = 0+'0';
		else{
			while(n!=0){
				str[len ++] = n%10 + '0';
				n /= 10;
			}
		}
		print(str, len);
	}
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值