第一次写博客,有点紧张。。。

也许格式也没有特别丑吧

先看原题(

此题做法众多,这里仅仅介绍蒟蒻的一种很复杂的思路(但最后还是喜提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:算数问题的更多相关文章

  1. 2021夏季学期华清大学EE数算OJ2:难缠的店长

    2021年夏季学期华清大学电子系数算oj2题解 某知名oier锐评蒟蒻的oj1题解: 话不多说,进入oj2题解: 难缠的oj 之 难缠的店长 当时读完我已经因为无良甲方的行为出离愤怒了!但是做题还是要 ...

  2. 2021春季学期华清大学EE数算OJ3:岩石的重量

    原题目如下: 看起来,这不过是我们在<程序设计基础>里面接触过的简单动态规划问题(什么,你不知道什么叫动态规划? 什么是动态规划? 百度百科对"动态规划"一词定义如下: ...

  3. 毕业样本=[华威大学毕业证书]Warwick原件一模一样证书

    华威大学毕业证[微/Q:2544033233◆WeChat:CC6669834]UC毕业证书/联系人Alice[查看点击百度快照查看][留信网学历认证&博士&硕士&海归& ...

  4. 热烈庆祝华清远见2014嵌入式系统(Linux&Android)开发就业培训课程全面升级

    近日,华清远见公开宣布:2014嵌入式系统 (Linux&Android)开发就业培训课程再次升级!据悉,华清远见如今已经持续10年,一直保持课程每年2次的更新的频率.华清远见的每 次课程更新 ...

  5. 基于华清远见STM32f051的 IIC从模式实现方法

    作者:卢老师,华清远见嵌入式学院讲师. 在大多情况下,我们使用MCU控制传感器,节点以及相关从设备,但在较为复杂的系统中,有时候也会使用MCU做为从设备. 下面是关于stm32f051的从模式实现方法 ...

  6. 热烈祝贺华清远见《ARM处理器开发详解》第2版正式出版

    2014年6月,由华清远见研发中心组织多名业 内顶尖讲师编写的<ARM处理器开发详解>一书正式出版.本书以S5PV210处理器为平台,详细介绍了嵌入式系统开发的各个主要环节,并注重实践,辅 ...

  7. [华清远见]FPGA公益培训

    本套视频教程为华清远见 网络公益培训活动,主讲人:姚远老师,华清远见高级讲师. ------------------------------------------------------------ ...

  8. 华清远见Linux设备驱动(每章小结)

    1.  linux设备驱动是以内核模块的方式而存在的,在具体的驱动开发中将驱动编译为模块具有很到的工程意义.因为如果将正在开发中的驱动编译如内核,而开发过程中会不断修改驱动代码,则需要不断的编译和重启 ...

  9. 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 ...

随机推荐

  1. nginx优化的一些建议

    1.1隐藏Nginx header里版本号信息 1.查看版本号 curl -I 127.0.0.1 HTTP/1.1 200 OK Server: nginx/1.6.2 Date: Sat, 14 ...

  2. -> 在c语言中是什么意思?

    ->在C语言中称为间接引用运算符,是二目运算符,优先级同成员运算符".".用法:p->a,其中p是指向一个结构体的指针,a是这个结构体类型的一个成员.表达式p-> ...

  3. .NET面试题整理

    .NET..NET Framework..NET Core和C#的解释各是什么? ASP.NET MVC和ASP.NET Web API的区别是什么? C#中的委托是什么?事件是不是一种委托? 简述P ...

  4. display:inline-block两端对齐 实现列表

    做一个ul li 列表类似这样的平时经常会用到 要是用浮动做还是比较简单的直接左右浮动,清除浮动就可以搞定了,因为最近用display:inline-block用的比较顺手,所以就尝试一下.通过tex ...

  5. 后端渲染神器!Dust

    Dust一个适用于浏览器与node的异步模板框架. 先上实例 后端模板: {@inject api="http://api.myserver.com/get_message"} & ...

  6. 聊聊 DisplayObject 的x/y/regX/regY/rotation/scale/skew 属性

    首先要指出的是:DisplayObject 实例的属性<x, y> 与 graphics.draw*(x, y, ...) 的参数<x, y>没有关系. 在原生的 Canvas ...

  7. 国际化相对时间格式化API:Intl.RelativeTimeFormat

    原文:The Intl.RelativeTimeFormat API 作者:Mathias Bynens(@mathias) 现代 Web 应用程序通常使用"昨天","4 ...

  8. Linux 0.11源码阅读笔记-内存管理

    内存管理 Linux内核使用段页式内存管理方式. 内存池 物理页:物理空闲内存被划分为固定大小(4k)的页 内存池:所有空闲物理页组成内存池,以页为单位进行分配回收.并通过位图记录了每个物理页是否空闲 ...

  9. 【Android开发】通过 style 设置状态栏,导航栏等的颜色

    <style name="test"> <!--状态栏颜色--> <item name="colorPrimaryDark"> ...

  10. 解决 Tomcat 控制台输出乱码(Tomcat Localhost Log / Tomcat Catalina Log 乱码)

    1. 按下图修改 先找到你的 Tomcat 安装目录,然后进入conf文件夹,找到 logging.properties,并打开它,然后把所有 UTF-8 格式的编码改成 GBK即可,具体操作如下图