Content

模拟一个系统,给出一个数 \(n\),让你判断是否是素数,如果是合数的话就要质因数分解。

需要注意的几点:

  • 数字超过 \(4\times 10^7\),输出溢出提示。
  • 数字小于 \(2\),输出 No! 之后直接进入下一次操作。
  • 数字是合数,则进行质因数分解,分解后的格式为x=x_1^a_1*x_2^a_2*...,其中 \(x_i\) 为这个数从小到大第 \(i\) 个质因子,\(a_i\) 为第 \(i\) 个质因子的指数。
  • 输出中会有各种友情提示和换行,请注意每一个细节。

数据范围:\(n\leqslant 4\times 10^7\)。

Solution

这道题目实质上是不难的,至于为什么评为蓝题,个人认为是这恶心的输出方式吧。

在这里给大家总结几点吧——

  • 要在输出完Enter the number=之后换行,不然满屏都是 \(\texttt{WA}\)。原因是第一行太长。
  • 要在每个数据之间空一行,不然也会有大面积的 \(\texttt{WA}\)。原因是在某一行会太长(这也就说明了本题的评测方式是逐行比对,且不忽略多余的空格、换行和制表符)。
  • Prime?之后一定要有一个空格!
  • 没有数字直接退出,不需要再输出多余的东西。
  • 数字溢出,输出完溢出提示后直接进入下一个操作,不需要再输出多余的东西。
  • 注意不需要再质因数分解中多出一些空格,诸如15 = 3 ^ 1 * 5 ^ 1等。

注意以上这几点,这道题目就不算难了。

Code

//注意这里省略了头文件
using namespace std; bool judge(int x) {
for(int i = 2; i <= floor(sqrt(x) + 0.5); ++i)
if(!(x % i)) return 0;
return 1;
}
void divide(int x) {
int flagone = 1;
for(int i = 2; i <= x; ++i)
if(!(x % i)) {
int cimi = 0;
while(!(x % i)) {
cimi++;
x /= i;
}
if(flagone) flagone = 0;
else printf("*");
printf("%d^%d", i, cimi);
}
} int main() {
while(1) {
printf("Enter the number=\n");
int num = 0, flag = 0, yichu = 0;
string sa;
getline(cin, sa);
int len = sa.size();
for(int i = 0; i < len; ++i) {
if(sa[i] >= '0' && sa[i] <= '9') {
flag = 1;
num = num * 10 + sa[i] - '0';
}
if(num > 40000000) {
printf("Prime? No!\nThe number is too large!\n\n");
yichu = 1;
break;
}
}
if(!flag) break;
if(yichu) continue;
printf("Prime? ");
if(num < 2) {
printf("No!\n\n");
continue;
}
if(judge(num)) {
printf("Yes!\n\n");
continue;
} else {
printf("No!\n%d=", num);
divide(num);
puts("\n");
}
}
}

LuoguP1619 解一元二次方程的烦恼 题解的更多相关文章

  1. 洛谷【P1619】 解一元二次方程的烦恼

    我对模拟的理解:https://www.cnblogs.com/AKMer/p/9064018.html 题目传送门:https://www.luogu.org/problemnew/show/P16 ...

  2. java练习题:解一元二次方程、判断闰年、判断标准身材、三个数取最大值

    1.解一元二次方程 注:求根公式为(-b+根号德尔塔)/2a,(-b-根号德尔塔)/2a Scanner sc=new Scanner(System.in); System.out.println(& ...

  3. C语言写解一元二次方程程序心得

    前言:在网上看到不少解一元二次方程的小程序,在使用时总得出一大堆小数,感觉很不爽,遂自己重新写了一遍. 首先,先回忆一下一元二次方程的求根公式: 分别读取二次项.一次项和常数项系数并且求出delta ...

  4. 【Java例题】2.8 解一元二次方程

    8.解一元二次方程. 输入一元二次方程的a,b,c三个系数,解一元二次方程 ax^2+bx+c=0,输出两个根 package study; import java.util.Scanner; pub ...

  5. c语言解一元二次方程

    C语言解一元二次方程,输入系数a,b,c; #include <stdio.h> #include <math.h> int main(int argc, char *argv ...

  6. 用c++解一元二次方程

    解方程 github项目地址 这两天得知初二的表妹学了一元二次方程,听说还不会解,我就想着试试用C语言编写解方程. 一元二次方程 用公式法 这种方法效果很好: #include"funct. ...

  7. if语句解一元二次方程~

    #include<stdio.h>#include<math.h> void main(){  double a,b,c,x1,x2;  printf("请输入a&q ...

  8. 解一元二次方程的C++实现

    一元二次方程的根的情况分为实根与虚根两种,代码如下 #include<iostream> #include<cmath> using namespace std; float ...

  9. 利用离散 Fourier 变换解一元二次方程

    设二次方程$$x^2+bx+c=0$$的两个根分别为 $x_1,x_2$.则$$(x-x_1)(x-x_2)=x^2+bx+c.$$因此$$\begin{cases}  x_1+x_2=-b\\x_1 ...

随机推荐

  1. [yLOI2018] 锦鲤抄

    先思考图上是\(tag\)的特殊情况. 考虑我们按拓扑序反过来操作,就可以得到我们任意想要的顺序. 那么我们把所有的图都缩点操作,那么我们只需要考虑一个联通分量里就行了. 一个联通分量最后只会剩下一个 ...

  2. 洛谷 P5046 [Ynoi2019 模拟赛] Yuno loves sqrt technology I(分块+卡常)

    洛谷题面传送门 zszz,lxl 出的 DS 都是卡常题( 首先由于此题强制在线,因此考虑分块,我们那么待查询区间 \([l,r]\) 可以很自然地被分为三个部分: 左散块 中间的整块 右散块 那么这 ...

  3. 洛谷 P3643 - [APIO2016]划艇(dp)

    题面传送门 一道难度中等的 \(dp\)(虽然我没有想出来/kk). 首先一眼 \(dp_{i,j}\) 表示考虑到第 \(i\) 个学校,第 \(i\) 个学校派出了 \(j\) 个划艇的方案数,转 ...

  4. 【转】群体研究套路:开心果denovo+重测序+转录组+群体进化+选择位点

    转自公众号Eric生信小班.学习群体遗传套路 中科院昆明动物园吴东东研究团队联合国外研究团队2019年在Genome Biology发表题为Whole genomes and transcriptom ...

  5. composer设置阿里云镜像源

    composer设置阿里云镜像源 1. 首先把默认的源给禁用掉 composer config -g secure-http false 2. 再修改镜像源 这里我使用阿里的源 composer co ...

  6. 在WEB网页上模拟人的操作(批量操作)

    思路:selenium IDE网页测试工具+firefox浏览器=>录制网页操作脚本->导出为Perl/python/Ruby/C/R等语言 参考: (1)selenium IDE网页测试 ...

  7. 完全用Deepin Linux娱乐、工作、学习(1)

    截至今天我已经用全Deepin Desktop Linux环境娱乐.工作.学习了100多天.当你看到这个桌面的时候,会不会觉得它是MacOS?错了,它是Deepin Desktop Linux,而且它 ...

  8. CentOS6安装Zabbix(RPM包)

    1. 系统环境状态 2. 安装zabbix4.0 3. 安装mysql+apache+php环境 4.配置mysql 5.配置zabbix-server 6. 配置apache 7. web安装 1 ...

  9. 推荐一个latex简历模板的网站给大家

    http://www.rpi.edu/dept/arc/training/latex/resumes/ Using the LaTeX Resume Templates A group of resu ...

  10. 关于写SpringBoot+Mybatisplus+Shiro项目的经验分享二:问题1

    框架: SpringBoot+Mybatisplus+Shiro 简单介绍:关于写SpringBoot+Mybatisplus+Shiro项目的经验分享一:简单介绍 添加时,如果失败,不能正确跳转 c ...