【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开发框架重要 ...
随机推荐
- body{display:none}
body{display:none} 使浏览器不显示内容,用这样的代码删除 $document = str_replace('body{display:none}','',$document);
- Font Awesome 图标如何使用
Font Awesome 图标如何使用 一.总结 一句话总结:Font Awesome字体图标非常好用,直接引入font-awesome.css,然后就可以直接使用了,使用的时候是用的i标签. 1.字 ...
- JS数据类型的转换规则
数据类型转换的规则 1 如果只有一个值,判断这个值是真还是假,遵循只有0,NaN,'',null,undefined这五个是假的,其余的都是真 2 如果是两个值比较是否相等,遵循以下规则: ![]-& ...
- JS学习笔记 - fgm练习 - 网页换肤
总结: 1. 点击按钮,div内部变色,边框保持颜色不变. 实现原理:其实本来就把background 和 border 分别设置了同一个颜色,看似是一个整体,其实本来就是分开的. 那么点击的时候,只 ...
- springboot集成shiro 实现权限控制(转)
shiro apache shiro 是一个轻量级的身份验证与授权框架,与spring security 相比较,简单易用,灵活性高,springboot本身是提供了对security的支持,毕竟是自 ...
- 从零开始使用git第二篇:git的日常操作
从零开始使用git 第二篇:git的日常操作 第一篇:从零开始使用git第一篇:下载安装配置 第二篇:从零开始使用git第二篇:git实践操作 第三篇:从零开始使用git第三篇:git撤销操作.分支操 ...
- (转载)iis7下站点日志默认位置
转自http://www.cnblogs.com/mincyw/p/3425468.html iis7下站点日志默认位置 在iis6时,通过iis管理器的日志配置可以找到站点日志存储的位置. 但是 ...
- 11.2 Android显示系统框架_android源码禁用hwc和GPU
2. 修改tiny4412_Android源码禁用hwc和gpu(厂家不会提供hwc和gpu的源代码,没有源代码就没法分析了,因此在这里禁用该功能并用软件库实现)最终源码: git clone htt ...
- Codeforces Round #315 (Div. 2) (ABCD题解)
比赛链接:http://codeforces.com/contest/569 A. Music time limit per test:2 seconds memory limit per test: ...
- 看朋友日志发现的一个ios下block相关的内存管理问题,非常奇怪,请大家帮忙一起来回答!
http://blog.csdn.net/fengsh998/article/details/38090205 这篇文章以下是我的回复.相同的代码仅仅是把变量的定义从局部变量改为类的成员变量就发现了非 ...