【t005】数字构造问题
Time Limit: 1 second
Memory Limit: 50 MB
【问题描述】
给定一个只包含数字[0..9]的字符串,请使用字符串中的某些字符,构建一个能够整除15最大的整数。注意,字符串中的每个字符只能使用一次。 任务:求由给定字符串构造的能够整除15的最大整数
【输入】
共1行;
输入数据为一个只包含数字[0..9]字符串,字符串的长度为1..1000。如果无法构建出该数字,请输出“impossible”。
【输出】
输出一行数字串,表示能够整除15的最大整数。
【输入样例】
02041
【输出样例1】
4200
【题目链接】:http://noi.qz5z.com/viewtask.asp?id=t005
【题解】
/*
一个数字能被15整除;
则这个数的各个位上的数字的和是3的倍数;
末尾数字是0或5.
把所有的数字从大到小排序;
所有数字的和模3的结果;
1.如果为0
如果数字里面有0,则排序后0在最后面,则直接输出;
如果数字里面没有0,但是有5,则把1个5放在最后面;然后输出;
else
put("Impossible");
2.如果为1
则如果有余数为1的数字,选那个最小的,删掉它;
如果没有余数为1的数字,找两个余数为2的数字;
{
如果有0,则直接找两个最小的,删掉
如果没有0,则要考虑
是不是减掉一个5之后,还能找到两个余数为2的数字;
能则删掉;
}
是否删掉了数字使得所有数字的和%3==0?
是则根据有没有5和0,输出相应的答案;
否则无解;
2.如果为2
则如果有1个余数为2的数字;
{
如果有0,则直接找最小的那个删掉;
如果没有0,则要考虑
是不是减掉一个5之后,还能找到一个余数为2的数字;
能则删掉那个数字,否则"去找两个余数为1的数字",删掉;
}
没有
则去找两个余数为1的数字;
如果有就删掉最小的两个;
是否删掉了数字使得所有数字的和%3==0?
是则根据有没有5和0,输出相应的答案;
否则无解;
*/
【完整代码】
#include <cstdio>
#include <string>
#include <iostream>
#include <algorithm>
using namespace std;
const int MAXN = 1000+100;
string s;
int bo[3];
int a[MAXN],n,num = 0,t5 = 0,t0 = 0;
bool ok1;
bool cmp(int x,int y)
{
return x > y;
}
void find5()
{
for (int i = 1;i <= n;i++)
if (a[i]==5)
{
a[i]=-1;
a[n+1] = 5;
break;
}
}
void output()
{
int l = 1,r = n+1;
while (a[l]==0 || a[l]==-1) l++;
if (l>r)
puts("0");
for (int i = l;i <= n+1;i++)
if (a[i]!=-1)
printf("%d",a[i]);
}
void pd()
{
if (ok1)//如果删掉数了
{
if (t0)//有0就直接输出
{
output();
exit(0);
}
if (t5)//执行这一段就表示没0,则如果有5就把5移到最后输出
{
find5();
output();
exit(0);
}
}
//没完成删数或没有0和5就输出无解
puts("impossible");
}
int main()
{
//freopen("F:\\rush.txt","r",stdin);
cin >> s;
n = s.size();
for (int i = 0;i <= n-1;i++)
{
a[i+1] = s[i]-'0';
bo[a[i+1]%3]++;
num+=a[i+1];
if (a[i+1]==5) t5++;
if (a[i+1]==0) t0++;
}
sort(a+1,a+1+n,cmp);
a[n+1] = -1;
int x = num%3;
if (x==0)
{
if (t0)
{
for (int i = 1;i <= n;i++)
printf("%d",a[i]);
return 0;
}
if (t5)
{
find5();
for (int i = 1;i <= n+1;i++)
if (a[i]!=-1)
printf("%d",a[i]);
return 0;
}
puts("impossible");
return 0;
}
if (x==1)
{
ok1 = false;
if (bo[1])
{
for (int i = n;i >= 1;i--)
if (a[i]%3==1)
{
a[i] = -1;
break;
}
ok1 = true;
}
if (!ok1 && bo[2]>=2)
{
if (t0>0)//直接找两个余数为2的删掉(最小)
{
int cnt = 0;
for (int i = n;i >= 1;i--)
if (a[i]%3==2)
{
cnt++;
a[i] = -1;
if (cnt==2)
break;
}
ok1 = true;
}
//如果没有0,则还需要一个5
//看一下删掉一个5(所以你得先有一个5)
//之后还有没有两个余数为2的)->所以bo[2]>=3是条件
if (!ok1 && t5 && bo[2]>=3)
{
//如果5只有一个,就不能选5
bool ban5 = false;
int cnt = 0;
if (t5==1)
ban5 = true;
for (int i = n;i>=1;i--)
if (a[i]%3==2)
{
if (ban5)
if (a[i]==5)
continue;
a[i] = -1;
cnt++;
if (cnt==2)
break;
}
ok1 = true;
}
}
//删数完成,根据0和5的个数判断输出
pd();
}
if (x==2)
{
ok1 = false;
if (bo[2])
{
if (t0)
{
for (int i = n;i>=1;i--)
if (a[i]%3==2)
{
a[i] = -1;
break;
}
ok1 = true;
}
//如果下面这段执行是肯定没有0了
//则肯定要有一个5,减去5会让bo[2]--,所以bo[2]要大于1
if (!ok1 && t5 && bo[2]>1)
{
bool ban5 = false;
if (t5==1)
ban5 = true;
for (int i = n;i >= 1;i--)
if (a[i]%3==2)
{
if (ban5)
if (a[i]==5)
continue;
a[i] = -1;
break;
}
ok1 = true;
}
}
if (!ok1 && bo[1]>=2)
{
int cnt = 0;
for (int i = n;i >= 1;i--)
if (a[i]%3==1)
{
a[i] = -1;
cnt++;
if (cnt==2)
break;
}
ok1 = true;
}
pd();
}
return 0;
}
【t005】数字构造问题的更多相关文章
- 浅谈无字母数字构造webshell
0x00 问题 <?php include 'flag.php'; if(isset($_GET['code'])){ $code = $_GET['code']; if(strlen($cod ...
- 【t030】数字构造
Time Limit: 3 second Memory Limit: 256 MB [问题描述] 有这么一个游戏: 写出一个1-N的排列a[i],然后每次将相邻两个数相加,构成新的序列,再对新序列进行 ...
- TTTTTTTTTTTTTT CF 95 B 构造4,7幸运数字 贪心 构造 string
B. Lucky Numbers time limit per test 2 seconds memory limit per test 256 megabytes input standard in ...
- 涨姿势:抛弃字母、数字和下划线写SHELL
PHP中异或 (^) 的概念 <?php echo"A"^"?";?> <?php echo"A"^"?&quo ...
- java面试题总汇
coreJava部分 7 1.面向对象的特征有哪些方面? 7 2.作用域public,private,protected,以及不写时的区别? 7 3.String 是最基本的数据类型吗? 7 4.fl ...
- BZOJ 4724: [POI2017]Podzielno
Description 由\([0,B-1]\)的数字构造一个 \(B\) 进制数字,使得他是 \(B-1\) 的倍数. Sol 贪心+二分. 首先 \(X\) 是 \(B-1\) 的倍数,那么有 \ ...
- boost学习笔记(七)---date_time库
date_time库的日期基于格里高利历,支持从1400-01-01到9999-12-31之间的日期计算 #define BOOST_DATE_TIME_SOURCE #include <boo ...
- Winform开发框架之统计图表的实现
在前面的一些随笔中,介绍了不少我的Winform框架的特性,上篇随笔<Winform开发框架之通用高级查询模块>对其中的通用高级模块进了一个整理说明,本篇继续介绍Winform开发框架重要 ...
- [转载]Winform开发框架之统计图表的实现
在前面的一些随笔中,介绍了不少我的Winform框架的特性,上篇随笔<Winform开发框架之通用高级查询模块>对其中的通用高级模块进了一个整理说明,本篇继续介绍Winform开发框架重要 ...
随机推荐
- Beginning iOS Programming
Beginning iOS Programming 2014年 published by Wrox
- Rdis-主从复制
配置 配置一个从服务器非常简单, 只要在配置文件中增加以下的这一行就可以了: slaveof 192.168.1.1 6379 注:主:bind 192.168.10.1 (指定主机IP) 当然, 你 ...
- (错误记录)Vue: Unknown custom element
错误: vue.js:634 [Vue warn]: Unknown custom element: <ve-pie> - did you register the component c ...
- Node.js笔记 请求方式 GET
三种方法解析url 1. 传统的字符串split切割方法 2. querystring 只能解析数据部分,不能解析前面 index.html之类的地址部分. 3. url 可以解析地址和数 ...
- ThinkPHP5.0---URL访问
ThinkPHP 5.0 在没有启用路由的情况下典型的URL访问规则是(采用 PATH_INFO 访问地址): http://serverName/index.php(或者其它应用入口文件)/模块/控 ...
- MES制造系统
给大家介绍一个非常不错的MES专业产品网站,http://www.OrBitMES.com 上面分为初.中.高各级的难得的MES产品学习资料下载, http://www.orbitmes.com/Pr ...
- leetcode 113. Path Sum II (路径和) 解题思路和方法
Given a binary tree and a sum, find all root-to-leaf paths where each path's sum equals the given su ...
- xmppframework开发基础
xmppframework是XMPP协议的一个objective-c实现. 要了解xmppframework, 从这里開始吧:https://github.com/robbiehanson/XMPPF ...
- 【Codeforces Round #439 (Div. 2) A】The Artful Expedient
[链接] 链接 [题意] [题解] 暴力 [错的次数] 在这里输入错的次数 [反思] 在这里输入反思 [代码] #include <bits/stdc++.h> using namespa ...
- GAS Syntax
GAS or GNU as syntax is a different form of syntax for assembly language files, known also as AT& ...