P1319 压缩技术

题目描述

设某汉字由N × N的0和1的点阵图案组成。

我们依照以下规则生成压缩码。连续一组数值:从汉字点阵图案的第一行第一个符号开始计算,按书写顺序从左到右,由上至下。第一个数表示连续有几个0,第二个数表示接下来连续有几个1,第三个数再接下来连续有几个0,第四个数接着连续几个1,以此类推……

例如: 以下汉字点阵图案:

0001000
0001000
0001111
0001000
0001000
0001000
1111111

对应的压缩码是: 7 3 1 6 1 6 4 3 1 6 1 6 1 3 7 (第一个数是N ,其余各位表示交替表示0和1 的个数,压缩码保证 N × N=交替的各位数之和)

输入格式

一行,压缩码。

输出格式

汉字点阵图(点阵符号之间不留空格)。(3<=N<=200)

输入输出样例

输入 输出
7 3 1 6 1 6 4 3 1 6 1 6 1 3 7 0001000
0001000
0001111
0001000
0001000
0001000
1111111

解答

#include<bits/stdc++.h>
using namespace std;

int main()
{
	int n,amount,num,all=0,flag=0,row=0;
	cin>>n;
	amount=n*n;
	int a[n][n];
	memset(a,0,sizeof(a));
	
	while(all<amount)
	{
		cin>>num;
		for(int i=0;i<num;i++)
		{
			a[row][all%n]=flag;
			all++;
			if(all>0 && all%n==0) row++;
		}
		if(flag==0) flag=1;
		else flag=0;
	}
	
	for(int i=0;i<n;i++)
	{
		for(int j=0;j<n;j++)
		{
			cout<<a[i][j];
		}
		cout<<endl;
	}

	return 0;
 } 
posted @ 2021-09-30 22:27  CodeSpark  阅读(202)  评论(0编辑  收藏  举报