2021夏季学期华清大学EE数算OJ1:算数问题
第一次写博客,有点紧张。。。
也许格式也没有特别丑吧
先看原题(
此题做法众多,这里仅仅介绍蒟蒻的一种很复杂的思路(但最后还是喜提0ms的好成绩)
读完这道题,不难发现,此题不过是一个质因数分解+一堆特判
1.质因数分解
作为无系的优秀学子,我们很自然的联想到《程序设计基础》中曾经多次出现的质因数分解。毕竟,本题要求我们输出的各个数位都是原数的因数,那么求解因数的方法在我们的思维中首先就是分解质因数啦。
此外,如果我们愿意多花一小段时间分析,我们也不难看出,如果输入的数字分解质因数后存在11或者更大的质因数,那么一定是不满足题目要求的!直接输出-1即可。
那么,对于其他的数字,其分解质因数的结果只能有:2,3,5,7;
比如,对于数字100,有质因数分解数列:2 2 5 5
因此,2255是满足题目条件的一个数。
2.合并质因数,减少数位
为了让数字最小,我们自然要让数位越小越好。对于2和3,有2*2*2=8,3*3=9,2*3=6,得到的仍然是一位数。那么,如果我们把原质因数列中的2和3合并起来,是不是就达到减少数位的目的了呢?
比如上述的2255,如果我们把2*2合并成4,得到455,其实就达到了减少数位的目的。
对于其他的乘法,自然也是一样的。
但是,对于众多的2和3,我们有很多合并的方式,但我们分析得出:当合并出的因数最大时,对我们减小数字是最有利的。
比如:72=2*2*2*3*3,我们最好的方法是89,而非其他的方案。
此处应用到简单的数学知识,自然难不倒作为无系dalao的你吧。
3.对数列进行排序,取得最小数
在进行第二步之前,由于我们在质因数分解时得到的数列是有序的,我们得到的数满足是“当前数位组成下的最小的数”。但是,合并数位后,我们得到的数字也许不再是有序的。
我采用的办法是,多开了一个数组,在合并质因数的时候直接在原数组中删去因数,在新数组中得到积,这样省去了繁琐的数组坐标移动过程。
然后再把两个数组拼接起来,用sort函数进行排序,就得到符合题意的最小数啦。
4.彩蛋
当我们兴致勃勃的开始评测的时候:

好似!开香槟喽!
结果:

作为无系oj的第一题,本题为大家准备了意外惊喜
我们从小就学过,自然数=正整数+0,那么再去阅读题干,聪明的你一定发现了出题人的深意吧!
附:AC代码
#include<cstdio>
#include<algorithm>
using namespace std;
int a[100],b[100];
int main(){
int n;
scanf("%d",&n);
if(!n){printf("10");return 0;}
if(n<10){printf("%d",n);return 0;}
int i,t=1;
for(int i=2;i*i<=n;i++){
while(!(n%i)){
a[t++]=i;n/=i;
}
}
if(n>1)a[t++]=n;
int l2=0,r2=0,r3=0,l3=0,q=1,bq=0;
for(int i=1;i<t;i++){
if(a[i]==2&&(!l2))l2=i;
if(a[i]==2&&a[i+1]!=2)r2=i;
if(a[i]==3&&(!l3))l3=i;
if(a[i]==3&&a[i+1]!=3)r3=i;
if(a[i]>3&&(!bq)){q=i;bq=1;}
if(a[i]>9){printf("-1");return 0;}
}
int num2=0,num3=0,bnum=1;
for(int i=l3;i<=r3&&r3>0;i++){
num3++;
if(num3==2){
b[bnum++]=9;
num3=0;
}
}
for(int i=l2;i<=r2&&r2>0;i++){
num2++;
if(num2==3){
b[bnum++]=8;
num2=0;
}
}
if(num2&&num3){b[bnum++]=6;num2--;num3--;}
if(num2==2){b[bnum++]=4;num2-=2;}
if(num3){b[bnum++]=3;num3--;}
if(num2){b[bnum++]=2;num2--;}
for(int i=t;i<t+bnum-1;i++)a[i]=b[i-t+1];
sort(a+q,a+bnum+t-1);
for(int i=q;i<t+bnum-1;i++)printf("%d",a[i]);
}
下次会好好调整格式的
2021夏季学期华清大学EE数算OJ1:算数问题的更多相关文章
- 2021夏季学期华清大学EE数算OJ2:难缠的店长
2021年夏季学期华清大学电子系数算oj2题解 某知名oier锐评蒟蒻的oj1题解: 话不多说,进入oj2题解: 难缠的oj 之 难缠的店长 当时读完我已经因为无良甲方的行为出离愤怒了!但是做题还是要 ...
- 2021春季学期华清大学EE数算OJ3:岩石的重量
原题目如下: 看起来,这不过是我们在<程序设计基础>里面接触过的简单动态规划问题(什么,你不知道什么叫动态规划? 什么是动态规划? 百度百科对"动态规划"一词定义如下: ...
- 毕业样本=[华威大学毕业证书]Warwick原件一模一样证书
华威大学毕业证[微/Q:2544033233◆WeChat:CC6669834]UC毕业证书/联系人Alice[查看点击百度快照查看][留信网学历认证&博士&硕士&海归& ...
- 热烈庆祝华清远见2014嵌入式系统(Linux&Android)开发就业培训课程全面升级
近日,华清远见公开宣布:2014嵌入式系统 (Linux&Android)开发就业培训课程再次升级!据悉,华清远见如今已经持续10年,一直保持课程每年2次的更新的频率.华清远见的每 次课程更新 ...
- 基于华清远见STM32f051的 IIC从模式实现方法
作者:卢老师,华清远见嵌入式学院讲师. 在大多情况下,我们使用MCU控制传感器,节点以及相关从设备,但在较为复杂的系统中,有时候也会使用MCU做为从设备. 下面是关于stm32f051的从模式实现方法 ...
- 热烈祝贺华清远见《ARM处理器开发详解》第2版正式出版
2014年6月,由华清远见研发中心组织多名业 内顶尖讲师编写的<ARM处理器开发详解>一书正式出版.本书以S5PV210处理器为平台,详细介绍了嵌入式系统开发的各个主要环节,并注重实践,辅 ...
- [华清远见]FPGA公益培训
本套视频教程为华清远见 网络公益培训活动,主讲人:姚远老师,华清远见高级讲师. ------------------------------------------------------------ ...
- 华清远见Linux设备驱动(每章小结)
1. linux设备驱动是以内核模块的方式而存在的,在具体的驱动开发中将驱动编译为模块具有很到的工程意义.因为如果将正在开发中的驱动编译如内核,而开发过程中会不断修改驱动代码,则需要不断的编译和重启 ...
- hdu 5228 OO’s Sequence(单独取数算贡献)
Problem Description OO has got a array A of size n ,defined a function f(l,r) represent the number o ...
随机推荐
- 遇到过的问题之“解决 No qualifying bean of type 问题”
1.问题 解决 No qualifying bean of type 问题 2.思路: 1 检查是否添加了对应注解 2 检查配置是否正确,扫描包名, 类名及id是否正确 一 . 传统SSM项目 ssm ...
- 语言算子&模糊推理
一.语言算子 语言算子分为三类: ①语气算子 ②模糊化算子 ③判定化算子 (1)语气算子 "集中化算子":--"很"."极"."非 ...
- poj_2386_dfs
描述 由于最近的一场雨,农夫john的田地里很多地方流入了水,由一个N*M的矩形表示.每个方格要么有水(W)要么是干的(.).农夫想要知道他的田地里形成了多少池塘. 一个池塘由有水的方块相连,每个方块 ...
- css3中什么时候用transition什么时候用animation实现动画
在css3中transition和animation都可以实现动画效果,但是我们什么时候用transition,什么时候用animation. 当有事件触发动画的时候我们就用transition.比如 ...
- APICloud首款全功能集成开发工具重磅发布,彰显云端一体理念
近日,APICloud重磅推出首款云端一体的全功能集成开发工具--APICloud Studio 2.为了更深入了解这款开发工具的特性及优势,APICloud CTO 邹达针对几个核心问题做出了解答. ...
- canvas小游戏——flappy bird
前言 如果说学编程就是学逻辑的话,那锻炼逻辑能力的最好方法就莫过于写游戏了.最近看了一位大神的fly bird小游戏,感觉很有帮助.于是为了寻求进一步的提高,我花了两天时间自己写了一个canvas版本 ...
- vux+vue-cli3.0坑
最近开发了项目使用了vue-cli3.0+vux搭建的项目,现在总结遇到的问题: 环境:github vux有关于vue-cli3.0以及vux已经搭建好的脚手架vux-cli3链接 一:如下报错 解 ...
- 如何在 Java 中实现无向环和有向环的检测
无向环 一个含有环的无向图如下所示,其中有两个环,分别是 0-2-1-0 和 2-3-4-2: 要检测无向图中的环,可以使用深度优先搜索.假设从顶点 0 出发,再走到相邻的顶点 2,接着走到顶点 2 ...
- MFC---视图和窗口
视类窗口 视类窗口是指程序运行后,显示信息的那一部分.对应的类是CTestOneView(TestOne表示项目名称)类,CTestOneView类是派生于CView类,而CView类又派生于CWnd ...
- js刷新页面window.location.reload()
window.location.reload()刷新当前页面 window.parent.location.reload()刷新父亲对象(用于框架) opener.location.reload()刷 ...