P2192 HXY玩卡片

23 篇文章 1 订阅

题目描述

HXY得到了一些卡片,这些卡片上标有数字0或5。现在她可以选择其中一些卡片排成一列,使得排出的一列数字组成的数最大,且满足被90整除这个条件。同时这个数不能含有前导0,即0不能作为这串数的首位。如果不能排出这样的数,输出“-1”。

输入输出格式

输入格式:

第一行,卡片的个数n。

第二行,分别给出了这n个数(只能为数字5或0)。

输出格式:

仅一行,如果可以排出,则输出这个数。否则输出“-1”。

输入输出样例

输入样例#1:
4
5 0 5 0
输出样例#1:
0
输入样例#2:
11
5 5 5 5 5 5 5 5 0 5 5
输出样例#2:
5555555550

说明

数据范围:

对于30%的数据,n<=10;

对于20%的数据,仅含数字5;

对于100%的数据,n<=1000。


#include<iostream>
using namespace std;

int main()
{
	int n;
	cin>>n;
	int a,x=0,y=0;
	for(int i=0;i<n;i++)
	{
		cin>>a;
		if(a==5)
			x++;
		else
			y++;
	}
	if(y==0)
		cout<<-1<<endl;
	else if(x<9)
		cout<<0<<endl;
	else
	{
		x-=x%9;
		for(int i=0;i<x/9;i++)
			cout<<"555555555";
		for(int i=0;i<y;i++)
			cout<<0;
	}
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值