• 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("
    ");
    		}
    		else
    		{
    			for(int i=0;i<k/2;i++) printf("8");
    			printf("4
    ");//也可以用6,或9;但不能用0,因为k=1的时候输出是0,不是正整数 
    		}//如果用0的话,需要在前面再加一个判断语句 
    	}
    	return 0;
    }



  • 相关阅读:
    ServU和win2003防火墙的设置
    面试题02.05 链表求和
    【每日一题】LeetCode1. 两数之和
    【每日一题】Leetcode50. Pow(x,n)
    ASP连接查询access和sqlserver的代码
    各种播放器(视频点播)代码大全 
    电脑操作最忌讳的小动作
    网络小知识
    C#、Java比较
    10年互联网十大失败案例
  • 原文地址:https://www.cnblogs.com/Friends-A/p/9309056.html
Copyright © 2020-2023  润新知