【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开发框架重要 ...
随机推荐
- java位运算应用
位移动运算符: <<表示左移, 左移一位表示原来的值乘2. 比如:3 <<2(3为int型) 1)把3转换为二进制数字0000 0000 0000 0000 0000 000 ...
- JAVA异常机制简述
1.类的继承结构 在JAVA所有的异常对象都是Throwable类的一个子类的实例 Exception包含两个分支,由于程序错误导致的异常属于RuntimeException,比如数组下标越界,空指针 ...
- 用c实现的各种排序的方法
#include <stdio.h> void swap(int *a, int *b); void bubble_sort(int a[], int n); void select_so ...
- XAMPP各个版本配置
XAMPP各个版本配置 http://code.stephenmorley.org/articles/xampp-version-history-apache-mysql-php/ XAMPP Ap ...
- javascript进阶教程第二章对象案例实战
javascript进阶教程第二章对象案例实战 一.学习任务 通过几个案例练习回顾学过的知识 通过案例练习补充几个之前没有见到或者虽然讲过单是讲的不仔细的知识点. 二.具体实例 温馨提示 面向对象的知 ...
- Mine Vison base on VC++ and procilica Gige Vison SDK
This is my first vision base on VC++6.0. I am so happy to record this time i succesfully create it b ...
- 知无涯者(The Man Who Knew Infinity)
1913年的1月16号在剑桥大学的三一学院那里,著名的数学家哈代教授收到了一封信,信的开头是这种: "尊敬的先生.仅自我介绍例如以下,我是马德拉斯港务信托处的一个职员,年薪唯独20英镑.23 ...
- TabControl控件重绘
原文地址:http://www.codeproject.com/Articles/91387/Painting-Your-Own-Tabs-Second-Edition 在网上看到重绘TabContr ...
- express,中间件(body-parser),req.body获取不到参数(含postman发请求的方法)
问题描述: 最近在做毕设,express 里边的中间件(body-parser)失效,req.body获取不到任何值,req.query能获取到值.一开始加body-parser中间件是有用的,直到昨 ...
- Qt5 UI信号、槽自动连接的控件重名大坑(UI生成的槽函数存在一个隐患,即控件重名。对很复杂的控件,不要在 designer 里做提升,而是等到程序启动后,再动态创建,可以避免很多问题)
对Qt5稍有熟悉的童鞋都知道信号.槽的自动连接机制.该机制使得qt designer 设计的UI中包含的控件,可以不通过显式connect,直接和cpp中的相应槽相关联.该机制的详细文章见 http: ...