最近开始了实验室的生活,并且学习了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的更多相关文章

  1. 暑假算法练习Day1

    为了加强个人的算法能力,所以准备每天都做适当的算法练习,并在隔天加以回顾. 依托PTA.Leetcode平台进行训练(暂定每天三题C++,对于Leetcode平台上的练习,由于其解题需以类的形式进行提 ...

  2. 算法学习--Day6

    题目描述 实现一个加法器,使其能够输出a+b的值. 输入描述: 输入包括两个数a和b,其中a和b的位数不超过1000位. 输出描述: 可能有多组测试数据,对于每组数据, 输出a+b的值. 示例1 输入 ...

  3. 暑假算法练习Day5

    咕咕了好几天哈哈哈哈,因为这几天在忙一些其他事(bushi ,好吧其实就是自己太懒啦,从今天开始继续每天的算法练习 1010 一元多项式求导 (25 分) 设计函数求一元多项式的导数.(注:\(x^n ...

  4. 暑假算法练习Day3

    第三天!!!最近要开始归纳总结Python学习啦!! 1006 换个格式输出整数 (15 分) 让我们用字母 B 来表示"百".字母 S 表示"十",用 12. ...

  5. 暑假算法练习Day4

    已经坚持第四天啦,Fighting!!! 1008 数组元素循环右移问题 (20 分) 一个数组\(A\)中存有\(N\)\((>0)\)个整数,在不允许使用另外数组的前提下,将每个整数循环向右 ...

  6. 暑假算法练习Day2

    第二天啦!大家一起冲冲冲!! 1004 成绩排名 (20 分) 读入 n(>0)名学生的姓名.学号.成绩,分别输出成绩最高和成绩最低学生的姓名和学号. 输入格式: 每个测试输入包含 1 个测试用 ...

  7. HDU2037 今年暑假不AC 贪心算法

    贪心算法 : 贪心算法就是只考虑眼前最优解而忽略整体的算法, 它所做出的仅是在某种意义上的局部最优解, 然后通过迭代的方法相继求出整体最优解. 但是不是所有问题都可以得到整体最优解, 所以选择贪心策略 ...

  8. 1187: 零起点学算法94——今年暑假不AC(Java)

    1187:零起点学算法94--今年暑假不AC Time Limit: 1 Sec Memory Limit: 32 MB 64bit IO Format: %lld Description " ...

  9. Day6 反射、模块、正则表达式和算法

    递归完成阶乘 def func(num): if num == 1: return 1 return num * func(num - 1) x = func(7) print(x) 反射 commo ...

随机推荐

  1. 15种Python片段去优化你的数据科学管道

    来源:15 Python Snippets to Optimize your Data Science Pipeline 翻译:RankFan 15种Python片段去优化你的数据科学管道 为什么片段 ...

  2. CRM是什么,你有认真了解过CRM吗?

    这是CRM的一个简单定义 客户关系管理 (CRM)是一种用于管理公司与客户和潜在客户的所有关系和互动的技术.目标很简单:改善业务关系.CRM 系统可帮助公司与客户保持联系.简化流程并提高盈利能力. 当 ...

  3. 从Gartner与IDC三大行业报告,看国产RPA的市场规模与未来发展

    从Gartner与IDC三大行业报告,看国产RPA的市场规模与未来发展 Gartner与IDC的三份报告,描绘出中国RPA的市场规模与未来宏图 文/王吉伟 近期的国产RPA,可谓捷报频频.三个重量级行 ...

  4. Spark MLib完整基础入门教程

    Spark MLib 在Spark下进行机器学习,必然无法离开其提供的MLlib框架,所以接下来我们将以本框架为基础进行实际的讲解.首先我们需要了解其中最基本的结构类型,即转换器.估计器.评估器和流水 ...

  5. 缓冲区溢出利用与ShellCode编写

    一.实验目的 熟悉编写shellCode的流程 掌握缓冲区溢出的利用 二.实验环境 系统环境:Windows环境 软件环境:C++ ,缓冲区溢出文件链接 三.实验原理 要实施一次有效的缓冲区溢出攻击, ...

  6. Mysql读写分离集群的搭建且与MyCat进行整合

    1. 概述 老话说的好:不熟悉的东西不要不懂装懂,做人要坦诚,知道就是知道,不知道就是不知道. 言归正传,今天我们来聊聊 Mysql主从读写分离集群是如何搭建的,并且聊一下如何用 MyCat 去访问这 ...

  7. 最新.NET MAUI有什么惊喜?

    .NET 6 Preview 7 现已发布啦,我们为 .NET 多平台应用程序 UI (MAUI) 引入了所有的新布局.这是性能和可靠性的重大变化.我们很高兴我们还增加了一些关于accessibili ...

  8. Get Mingw-w64 via MSYS2

    Get Mingw-w64 via MSYS2 Get the latest version of Mingw-w64 via MSYS2, which provides up-to-date nat ...

  9. Visual Studio 安装 C++

    Visual Studio 安装 C++

  10. Golang通脉之map

    Go语言中提供的映射关系容器为map,其内部使用散列表(hash)实现. map 是一种无序的键值对的集合.map 最重要的一点是通过 key 来快速检索数据,key 类似于索引,指向数据的值 map ...