暑假算法练习Day6
最近开始了实验室的生活,并且学习了bullet journal。希望接下来的每一天都能完成所有的任务。
1012 数字分类 (20 分)
给定一系列正整数,请按要求对数字进行分类,并输出以下 5 个数字:
- \(A_1\) = 能被 5 整除的数字中所有偶数的和;
- \(A_2\) = 将被 5 除后余 1 的数字按给出顺序进行交错求和,即计算 \(n_1−n_2+n_3−n_4⋯\);
- \(A_3\) = 被 5 除后余 2 的数字的个数;
- \(A_4\) = 被 5 除后余 3 的数字的平均数,精确到小数点后 1 位;
- \(A_5\) = 被 5 除后余 4 的数字中最大数字。
输入格式:
每个输入包含 1 个测试用例。每个测试用例先给出一个不超过 1000 的正整数 N,随后给出 N 个不超过 1000 的待分类的正整数。数字间以空格分隔。
输出格式:
对给定的 N 个正整数,按题目要求计算 A1~A5 并在一行中顺序输出。数字间以空格分隔,但行末不得有多余空格。
若其中某一类数字不存在,则在相应位置输出
N。
输入样例 1:
13 1 2 3 4 5 6 7 8 9 10 20 16 18
输出样例 1:
30 11 2 9.7 9
输入样例 2:
8 1 2 4 5 6 7 9 16
输出样例 2:
N 11 2 N 9
解题分析及代码:
本题其实比较简单,分情况依次讨论即可。但需要注意的是,在处理\(A_2\)的时候,不能以\(A_2\)是否为0作为其是否存在的判断依据,因为交错求和结果\(A_2\)是可能为0的,所以我采用对其个数是否为0进行判断。
#include <iostream>
#include <cstring>
#include <algorithm>
#include <cstdio>
#include <cmath>
#include <iomanip>
using namespace std;
int cmp(int a,int b){
return a>b;
}
int main() {
int n=0;
cin >> n;
int a=0;
int a1=0,a2=0,a3=0,a5=0;
int A2[1005]={0};
int n2=0,n4=0;
double a4=0;
for(int i=0;i<n;i++){
cin >> a;
if(a%10==0) a1+=a; //A1
else if(a%5==1) A2[n2++]=a; //A2
else if(a%5==2) a3++;//A3
else if(a%5==3){//A4
n4++;
a4+=a;
}
else if(a%5==4&&a>a5)a5=a;//A5
}
if(n4!=0)a4/=n4;
if(n2!=0){
int b=1;
for(int i=0;i<n2;i++){
A2[i]*=b;
a2+=A2[i];
b*=-1;
}
}
if(a1==0) cout << 'N'; //A1output
else cout << a1 ;
cout <<" ";
if(n2==0) cout << 'N';//A2output
else cout << a2 ;
cout <<" ";
if(a3==0) cout << 'N';//A3output
else cout << a3 ;
cout <<" ";
if(n4==0) cout << 'N';//A4output
else cout <<setiosflags(ios::fixed)<<setprecision(1)<< a4 ;
cout <<" ";
if(a5==0) cout << 'N';//A5output
else cout << a5 ;
cout << endl;
return 0;
}
1013 数素数 (20 分)
令 \(P_i\)表示第\(i\)个素数。现任给两个正整数 \(M≤N≤104\),请输出 \(P_M\)到 \(P_N\) 的所有素数。
输入格式:
输入在一行中给出 \(M\) 和\(N\),其间以空格分隔。
输出格式:
输出从\(P_M\)到 \(P_N\) 的所有素数,每 10 个数字占 1 行,其间以空格分隔,但行末不得有多余空格。
输入样例:
5 27
输出样例:
11 13 17 19 23 29 31 37 41 43
47 53 59 61 67 71 73 79 83 89
97 101 103
解题分析及代码:
本题其实是对素数判断的另一种运用,会写素数判断,其实问题就迎刃而解啦!
#include <iostream>
#include <cstring>
#include <algorithm>
#include <cstdio>
#include <cmath>
using namespace std;
bool IsPrime(int a){
int b=sqrt(a);
if(a==1) return false;
else if (a==2) return true;
else{
for(int i=2;i<=b;i++){
if(a%i==0) return false;
}
return true;
}
}
int main() {
int m,n;
cin >> m >> n;
int n1=0,n2=0;
for(int i=2;n1<n;i++){
if(IsPrime(i)==true){
n1++;
if(n1>=m){
n2++;
cout << i;
if(n2%10==0) cout << endl;
else if(n1!=n) cout <<" ";
}
}
}
return 0;
}
暑假算法练习Day6的更多相关文章
- 暑假算法练习Day1
为了加强个人的算法能力,所以准备每天都做适当的算法练习,并在隔天加以回顾. 依托PTA.Leetcode平台进行训练(暂定每天三题C++,对于Leetcode平台上的练习,由于其解题需以类的形式进行提 ...
- 算法学习--Day6
题目描述 实现一个加法器,使其能够输出a+b的值. 输入描述: 输入包括两个数a和b,其中a和b的位数不超过1000位. 输出描述: 可能有多组测试数据,对于每组数据, 输出a+b的值. 示例1 输入 ...
- 暑假算法练习Day5
咕咕了好几天哈哈哈哈,因为这几天在忙一些其他事(bushi ,好吧其实就是自己太懒啦,从今天开始继续每天的算法练习 1010 一元多项式求导 (25 分) 设计函数求一元多项式的导数.(注:\(x^n ...
- 暑假算法练习Day3
第三天!!!最近要开始归纳总结Python学习啦!! 1006 换个格式输出整数 (15 分) 让我们用字母 B 来表示"百".字母 S 表示"十",用 12. ...
- 暑假算法练习Day4
已经坚持第四天啦,Fighting!!! 1008 数组元素循环右移问题 (20 分) 一个数组\(A\)中存有\(N\)\((>0)\)个整数,在不允许使用另外数组的前提下,将每个整数循环向右 ...
- 暑假算法练习Day2
第二天啦!大家一起冲冲冲!! 1004 成绩排名 (20 分) 读入 n(>0)名学生的姓名.学号.成绩,分别输出成绩最高和成绩最低学生的姓名和学号. 输入格式: 每个测试输入包含 1 个测试用 ...
- HDU2037 今年暑假不AC 贪心算法
贪心算法 : 贪心算法就是只考虑眼前最优解而忽略整体的算法, 它所做出的仅是在某种意义上的局部最优解, 然后通过迭代的方法相继求出整体最优解. 但是不是所有问题都可以得到整体最优解, 所以选择贪心策略 ...
- 1187: 零起点学算法94——今年暑假不AC(Java)
1187:零起点学算法94--今年暑假不AC Time Limit: 1 Sec Memory Limit: 32 MB 64bit IO Format: %lld Description " ...
- Day6 反射、模块、正则表达式和算法
递归完成阶乘 def func(num): if num == 1: return 1 return num * func(num - 1) x = func(7) print(x) 反射 commo ...
随机推荐
- .NET 5 WPF 调用OCX 经验分享
在.Net 5.0 WPF中调用OCX步骤如下: 1,用工具先把ocx转换成AxInterop.EloamViewLib.dll和Interop.EloamViewLib.dll.(这里是我用到的oc ...
- 解决 Delegate IDE build/run actions to Maven 编译两次的问题
起因:我的电脑炸了,吸取教训,以后重要的东西千万不要存在C盘,特别是我们 IT 行业的,代码和文档都是一点一点积累的经验.突然没了,总感觉少了点啥,平时我的代码都是放在D盘,但是很多文档放在C盘,导致 ...
- NOIP模拟72
T1 出了个大阴间题 解题思路 看了看数据,大概是个状压 DP,但是感觉记忆化搜索比较好写一点(然而并不是这样递归比迭代常熟大了许多..) 不难判断出来 b 的数值与合并的顺序无关于是我们可以预先处理 ...
- python日志配置及调用
0.日志基础操作 import logging logging.basicConfig( #1.日志输出的位置,终端和文件 filename='access.log', #,不指定默认打到终端上 #2 ...
- 教你 4 步搭建弹性可扩展的 WebAPI
作者 | 萧起 阿里云云原生团队 本文整理自<Serverless 技术公开课>,关注"Serverless"公众号,回复"入门",即可获取 Se ...
- VS Code环境配置
1.语言配置 2.Node.js安装配置 系统变量中NODE_PATH,变量值为nodejs的安装路径. 用户变量Path包含%NODE_PATH% 如果说通过CMD打开的命令行可以执行node -v ...
- AT3950 [AGC022E] Median Replace
题目传送门 Description 有一个长度为 \(n\) 的 \(01\) 串,里面有一些还没有确定,我们标记为 ? .可以进行若干次操作,每次操作可以把三个相邻的数替换成它们的中位数.问有多少种 ...
- 题解 SP6779 【GSS7 - Can you answer these queries VII】
题目传送门 题目大意 给出一个\(n\)个点的树,每个点有权值.有\(m\)次操作,每次要么查询一条链上的最大子段和,要么把一条链的权值都修改为一个常数. \(n,m\le 10^5\) 思路 如果是 ...
- 01_vue实例_数据_方法
创建实例 var vm = new Vue( { //选项 } ) 数据对象 // 我们的数据对象 var data = { a: 1 } // 该对象被加入到一个 Vue 实例中 var vm = ...
- CentOS 7安装docker环境
一.环境准备 Docker支持以下的CentOS版本: 1.Docker运行在CentOS 7(64-bit)上要求系统为64位,系统内核版本为3.10以上 2.Docker运行在Centos 6.5 ...