Codeforces Round #462 (Div. 2) B-A Prosperous Lot

B. A Prosperous Lot
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output

Apart from Nian, there is a daemon named Sui, which terrifies children and causes them to become sick. Parents give their children money wrapped in red packets and put them under the pillow, so that when Sui tries to approach them, it will be driven away by the fairies inside.

Big Banban is hesitating over the amount of money to give out. He considers loops to be lucky since it symbolizes unity and harmony.

He would like to find a positive integer n not greater than 1018, such that there are exactly k loops in the decimal representation of n, or determine that such n does not exist.

loop is a planar area enclosed by lines in the digits' decimal representation written in Arabic numerals. For example, there is one loop in digit 4, two loops in 8 and no loops in 5. Refer to the figure below for all exact forms.

Input

The first and only line contains an integer k (1 ≤ k ≤ 106) — the desired number of loops.

Output

Output an integer — if no such n exists, output -1; otherwise output any such n. In the latter case, your output should be a positive decimal integer not exceeding 1018.

Examples
input
2
output
462
input
6
output
8080

题意:输入一个数k来表示一串数里面包含的封闭部分(如:8有2个,4、6、9分别有1个,5没有……),输出一组有k部分封闭的数(正整数),输出不超过 1018

/*36/2=18,所以输出不为-1的k的最大值为36
  因为8有两个部分封闭,所以当k是奇数的时候可以用有一个封闭部分的数(如4,6,9)来补上。 
  */
#include<bits/stdc++.h>
int main()
{
	int k;
	scanf("%d",&k);
	if(k>36) printf("-1");
	else
	{
		if(k%2==0)//判断奇偶 
		{
			for(int i=0;i<k/2;i++) printf("8");
			printf("\n");
		}
		else
		{
			for(int i=0;i<k/2;i++) printf("8");
			printf("4\n");//也可以用6,或9;但不能用0,因为k=1的时候输出是0,不是正整数 
		}//如果用0的话,需要在前面再加一个判断语句 
	}
	return 0;
}



posted @ 2018-02-16 22:13  友人-A  阅读(218)  评论(0编辑  收藏  举报