SPOJ 416 - Divisibility by 15(贪心)
糟烂的代码啊... 这个题目思路很简单——末位只可能为0和5,所有数字的和肯定被3整除
没有0和5的肯定不行
否则,把所有数字求和
如果被3整除,则从大到小输出
如果除3余1,则按以下顺序——删1;删4;删7;删2、5、8中的2个(特别注意如果没有0要保留一个5)
如果除3余2,则按以下顺序——删2;删5(特别注意如果没有0要保留);删8;删1、4、7中的2个
下面是糟烂的代码——
//糟烂代码总结 —— 没有章法,思路不清,逻辑性太高,导致找不出错 //以后写代码引以为戒 #include <stdio.h>
#include <string.h>
#include <math.h>
#include <algorithm>
using namespace std;
char s[1010];
int num[12];
int check(int sum)
{
if(!num[0]&&!num[5])return 0;
if(sum==0)return 1;
if(num[0])return 1;
if(sum%3==1)
{
if(num[1]==0&&num[4]==0&&num[7]==0&&(num[2]+num[5]+num[8]<2))
{
return 0;
}
}
else if(sum%3==2)
{
if(num[5])
{
if(num[2]==0&&num[5]<=1&&num[8]==0&&(num[1]+num[4]+num[7]<2))
{
return 0;
}
}
else
{
if(num[2]==0&&num[5]==0&&num[8]==0&&(num[1]+num[4]+num[7]<2))
{
return 0;
}
}
}
return 1;
}
int solve(int sum)
{
int ct=0;
if(sum==0)
{
printf("0\n");return 0;
}
if(sum%3==1)
{
ct=1;
if(num[1]){num[1]--;sum-=1;ct--;}
else if(num[4]){num[4]--;sum-=4;ct--;}
else if(num[7]){num[7]--;sum-=7;ct--;}
else
{
ct=2;
if(num[0]==0)
{
for(int i=2; i<=8; i+=3)
{
if(ct==0)break;
if(i==5&&num[i]==1)continue;//此处写错导致错误(原来是写的num[5]==1,影响到了8)
while(num[i]>0)
{
num[i]--;
ct--;
sum-=i;
if(ct==0)break;
if(i==5&&num[i]==1)break;
}
}
}
else
{
for(int i=2; i<=8; i+=3)
{
if(ct==0)break;
while(num[i]>0)
{
num[i]--;
ct--;
sum-=i;
if(ct==0)break;
}
}
} }
if(ct>0)
{
printf("impossible\n");
return 0;
}
}
else if(sum%3==2)
{
ct=1;
if(num[2]){num[2]--;sum-=2;ct--;}
else if(num[5]==1&&num[0]>0){num[5]--;sum-=5;ct--;}
else if(num[5]>1){num[5]--;sum-=5;ct--;}
else if(num[8]){num[8]--;sum-=8;ct--;}
else
{
ct=2;
for(int i=1; i<=7; i+=3)
{
if(ct==0)break;
while(num[i]>0)
{
num[i]--;
ct--;
sum-=i;
if(ct==0)break;
}
}
}
if(ct>0)
{
printf("impossible\n");
return 0;
}
}
if(num[0])
{
if(sum==0)printf("0");
else
for(int i=9; i>=0; i--)
{
for(int j=0; j<num[i]; j++)
printf("%d",i);
}
printf("\n");
}
else
{
num[5]--;
for(int i=9; i>=0; i--)
{
for(int j=0; j<num[i]; j++)
printf("%d",i);
}
printf("5\n");
}
}
int main()
{
int T;
//freopen("in.txt","r",stdin);
//freopen("out.txt","w",stdout);
scanf("%d",&T);
while(T--)
{ scanf("%s",s);
int l=strlen(s);
memset(num,0,sizeof(num));
int sum=0;
for(int i=0; i<l; i++)
{
num[s[i]-'0']++;
sum+=s[i]-'0';
}
if(!check(sum))
{
printf("impossible\n");
}
else
{
solve(sum);
}
}
return 0;
}
SPOJ 416 - Divisibility by 15(贪心)的更多相关文章
- SPOJ 416 Divisibility by 15 细节题
一个结论:一个数,如果它的所有数字之和能被3整除,那么这个数也能被3整除. 最后一位肯定是0或者5,如果没有就impossible. 剩下的就是,如何删除尽量少的数,使所有数字之和为3的倍数. 情况比 ...
- spoj 416
又臭又长的烂代码 ...... #include <iostream> #include <cstdio> #include <cstring> #include ...
- 【贪心】【Uva11729】 Commando War
你有n个部下,每个部下需要完成一项任务.第i个部下需要你花Bi分钟交待任务,然后他会立刻独立地.无间断地执行Ji分钟后完成任务.你需要选择交待任务的顺序,使得所有任务尽早执行完毕(即最后一个执行完的任 ...
- Team Foundation Server 2013 with Update 3 Install LOG
[Info @10:14:58.155] ====================================================================[Info @ ...
- 「PKUSC2018」主斗地(暴搜)
这道斗地主比 \(PKUWC\) 那道可做多了... 我们用 \(NOIP\) 那道斗地主的思路:暴搜出三代和四代,贪心出散牌. 还有jry为什么要出xx网友而不出他的另一个老婆 我们发现两个人的每回 ...
- (2) 我的结果- spec2006中精确的simulation points运行点
spec06中获取simpoints的环境说明: spec的版本号为spec2006v1.0; 使用ref input with runspec; 100millions为周期生成的simpoints ...
- Bayesian Optimization使用Hyperopt进行参数调优
超参数优化 Bayesian Optimization使用Hyperopt进行参数调优 1. 前言 本文将介绍一种快速有效的方法用于实现机器学习模型的调参.有两种常用的调参方法:网格搜索和随机搜索.每 ...
- SPOJ Find the max XOR value(二进制,贪心即可)
You have two integers L and R, and you are required to find the max xor value of a and b where L < ...
- 【2019.8.15 慈溪模拟赛 T1】插头(plugin)(二分+贪心)
二分 首先,可以发现,最后的答案显然满足可二分性,因此我们可以二分答案. 然后,我们只要贪心,就可以验证了. 贪心 不难发现,肯定会优先选择能提供更多插座的排插,且在确定充电器个数的情况下,肯定选择能 ...
随机推荐
- [php基础]PHP.INI配置:Session配置详细说明教程
网上有很多PHP.INI文件配置的中文说明,但是对于PHP初学者来说在进行PHP运行环境搭建配置时还是容易一头雾水,今天换一种角度来分享如何进行php.ini配置,以求达到解决实际问题的效果,开篇以P ...
- sql sever 随机查询
Select * From TableName Order By NewID() NewID()函数将创建一个 uniqueidentifier 类型的唯一值.上面的语句实现效果是从Table中随 ...
- Linux误删C基本运行库libc.so.6急救方法
首先普及一下关于libc.so.6的基本常识: libc.so.6是glibc的软链接 ll /lib64/libc.so.6lrwxrwxrwx 1 root root 11 Aug 27 201 ...
- mysql window下tmpdir空间耗尽
修改my.ini或my-default.ini文件[mysqld]下方配置 tmpdir = D:/tmp
- 使用2to3转换python代码
如果要把python2编译器下的代码转换升级到python3编译器,可以使用python自带的 2to3工具进行转化: windows下转化: doc 命令窗口: >> python C ...
- (function(){})(jQuery)的功能和用途?
1.为什么开发插件都这么写? 2.为什么要穿jQuery进去?在方法中直接用jquery的方法什么的不行吗? 1 首先(function(){})()这种写法 是创建了一个匿名的方法并立即执行(fun ...
- nginx 参数记录
log_format custom '$remote_addr - $remote_user [$time_local] ' '"$request" $status $reques ...
- 【iOS问题】字典转模型,属性个数不匹配问题
一.字典转模型的键值对与模型属性不匹配问题 1. 字典的键个数 < 模型的属性个数 (key 能与模型的属性匹配) 1> .KVO 方式: - setValuesForKeysWithDi ...
- SSD、高级格式化硬盘,4K,分区,对齐,Ghost能不能用的解释用SSD的都可以看看
或者以上,建议选择2048,这是Win7分区使用的值,实际对齐大小就为1024K. 4.如何知道是否对齐? 使用工具AS SSD Benchmark(HDTune Pro 4.6目前测的禁绝) ...
- data-theme 几种值的样式
代码片段: <div data-role="page"> <div data-role="header"> <h1>The ...