上周就说补题了,结果状态不佳…qwq,这周末把它给解决掉,实属不能再拖了QAQ。

作为一个只能借力签到的小白,我只能用上面三个表情包来表达内心的凄凉…凉qwq.

A. 张老师和菜哭武的游戏
时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 262144K,其他语言524288K
64bit IO Format: %lld
题目描述
天才程序员菜哭武和张老师有一天到一个城市旅游,旅途中菜哭武觉得无聊就想和张老师玩一个游戏。菜哭武有n个石子,每个石子都标有1到n之间到数,且各不相同,一开始他们会随机从这堆石子选一个石子放置到一个集合中,张老师选的数是a,菜哭武选的是b(a和b不相同)。接下来菜哭武和张老师轮流按照如下规则拿走一个石子:当石子x能被拿走时,当且仅当集合存在y和z,满足x等于y+z或者y-z,当x被拿走时,把它放到集合中。谁完成最后一轮操作时,谁获胜。张老师总是先手,于是张老师就好奇当决定好a和b时,他是否总是能获胜,你能帮助一下张老师吗?

输入描述:
第一行一个整数T(1≤T≤500),表示共有T组测试数据。
对于每组测试数据,第一行三个整数n(2≤n≤20000)、a和b(1≤a,b≤n, a≠b)。

输出描述:
若张老师能获胜输出Yes,反之No。

示例1:

输入
16
2 1 2
3 1 3
67 1 2
100 1 2
8 6 8
9 6 8
10 6 8
11 6 8
12 6 8
13 6 8
14 6 8
15 6 8
16 6 8
1314 6 8
1994 1 13
1994 7 12

输出
No
Yes
Yes
No
No
No
Yes
Yes
No
No
Yes
Yes
No
Yes
No
No

// A (博弈论,找规律)
#include <bits/stdc++.h>
using namespace std;
int main()
{int t,a,b,n;cin>>t;while(t--){ // &表示:位操作命令->按位与,即:相应的 bit位值同为1时结果为 1,否则结果为 0cin>>n>>a>>b;if(n/__gcd(a,b)&1) cout<<"Yes"<<endl;else cout<<"No"<<endl; }
}

B. 伤害计算
时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 262144K,其他语言524288K
64bit IO Format: %lld
题目描述
勇士菜哭武获得了一把新的武器,武器有特殊的伤害计算方式。武器的伤害计算方式由若干个部分的和组成,用+号连接。每一部分可以是一个整数a,或者是一个公式ndx。其中a表示固定伤害a点;ndx表示掷n个x面骰子,伤害是所有骰子点数的和。总伤害是每一部分伤害的和。

比如2d6+1d70+3,表示掷两个6面骰子和一个70面骰子(不一定实际存在70面骰子,可以理解成1到70当中随机选择一个整数),再加上固定伤害3点。

他正准备挑选一把好武器,需要计算新武器的伤害期望值,想让你帮他计算一下。

输入描述:
输入一个字符串,表示伤害计算公式。字符串长度不超过5000,对于每一个部分,1≤a, n, x≤1000。a,n,x都是整数。

输出描述:
输出一个数,表示伤害的期望值。如果不是整数,小数点后位数保留最少,即最终结果只有可能是整数或者小数点后是.5的形式,如果不是整数,那么保留一位小数。

示例1:

输入
1d6+1d70+1d10+6

输出
50.5

// B (字符串)
#include<bits/stdc++.h>
#define db double double
using namespace std;
const int N=5e5+1000;
char s[N];
double p[N];void init()
{double sum=0;for(int i=1;i<=1005;i++){sum+=i;p[i]=sum/i;}
}int main()
{init();scanf("%s",(s+1));int n=strlen(s+1);double res=0;for(int i=1;i<=n;i++) {int l=0,r=0,f=0,lazy=0;while(s[i]!='+'&&s[i]!='\0'&&i<=n){if(s[i]=='d') {f=1; lazy=1; i++; continue;}if(f==0) l=l*10+s[i]-'0';if(f==1) r=r*10+s[i]-'0';i++;}if(lazy==1) res=res+l*1.0*p[r];else res=res+l;}int x=(int)  res;if((double)x==res)  printf("%d\n",x);else  printf("%.1lf\n",res);
}

F. 排列计算
时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 262144K,其他语言524288K
64bit IO Format: %lld
题目描述
天才程序员菜哭武和石头组队参加一个叫做国际排列计算竞赛 (International Competition of Permutation Calculation, ICPC) 的比赛,这个比赛的规则是这样的:

一个选手给出一个长度为 n 的排列,另一个选手给出 m 个询问,每次询问是一个形如 (l, r) 的数对,查询队友给出的排列中第 l 个数到第 r 个数的和,并将查询到的这个区间和加入总分,最后总分最高的队伍就能获胜。

石头手速很快,在比赛一开始就给出了 m 个询问;菜哭武也很强,他总是能找到最合适的排列,使得他们队的总分尽可能高。

在看比赛直播的你看到了石头给出的 m 个询问,聪明的你能不能预测出他们队伍最终的得分呢?

一个排列是一个长度为 n 的数列,其中 1 ~ n 中的每个数都在数列中恰好出现一次。比如 [1, 3, 2] 是一个排列,而 [2, 1, 4] 和 [1, 2, 3, 3] 不是排列。

输入描述:
第一行输入两个数 n (1≤n≤2×105) 和 m (1≤m≤2×105) 。
接下来 m 行,每行输入两个数 l 和 r ,代表这次查询排列中第 l 个到第 r 个的和。

输出描述:
输出一个整数,代表他们队伍总分的最大值。

示例1:

输入

7 3
1 3
3 7
5 6

输出
46

说明:
一个符合条件的排列是 [1,3, 6, 4, 7, 5, 2],于是最终的得分为 (1 + 3 + 6) + (6 + 4 + 7 + 5 + 2) + (7 + 5) = 46

// F (差分)
#include<bits/stdc++.h>
using namespace std;
const int N=2e5+10000;
typedef long long ll;
ll a[N];
int n,m,l,r;
int main()
{scanf("%d %d",&n,&m);while(m--){scanf("%d %d",&l,&r);a[l]+=1;a[r+1]-=1;}for(int i=1;i<=n;i++) a[i]+=a[i-1];ll sum=0;sort(a+1,a+1+n);for(int i=n;i>=1;i--) sum=sum+(ll)a[i]*i;cout<<sum<<endl;
}

第十七届“科大讯飞杯”题解相关推荐

  1. 第十七届“科大讯飞杯”高校网络友谊赛——F-排列计算

    F-排列计算 题目描述 天才程序员菜哭武和石头组队参加一个叫做ICPC的比赛,这个比赛的规则是这样的: 一个选手给出一个长度为 n 的排列,另一个选手给出 m 个询问,每次询问是一个形如 (l, r) ...

  2. 2020第十七届华为杯数模C题——P300脑电信号数据预处理算法

    脑电信号数据预处理   这两天的数学建模选的C题,目标是要处理脑电P300信号的数据并进行相关预测任务.该题重点是数据预处理,因此根据最后实验的结果,分享相关的预处理方法以及源代码.长话短说,给出任务 ...

  3. 第十届蓝桥杯题解(部分)

    第十届蓝桥杯题解 注释:这段时间正好在写蓝桥杯的题,将部分的题目的解法和大家分享,代码中的网址是该代码蒟蒻当时参考其他大佬的题解文章所在的网址,鸣谢大佬,如有错误,欢迎各位大佬指正 有部分网址是提交答 ...

  4. 第十七届“振兴杯”全国青年 职业技能大赛——计算机程序设计员(云计算平台与运维)参赛回顾与总结

    目录 振兴杯官网:"振兴杯"全国青年职业技能大赛 (zxbds.cn) 市赛前期准备与回顾 国赛前期准备回顾 大赛通知 国赛回顾 云网络试题部分 云运维及云开发部分 国赛总结 参赛 ...

  5. 关于十七届恩智浦杯安徽赛区基础组参赛分享

    竞赛场地材料采用PVC耐磨塑胶地板材料制作(赛道宽35cm),具有黑色边界线和循迹电磁线.赛道中心铺设漆包线(电磁线),漆包线通有交变电流,车模通过电磁探测板检测实现自主循迹运动.黑色边界线由50mm ...

  6. 第十七届“振兴杯”全国青年职业技能竞赛(职工组)计算机程序设计员理论试题题库

    一.单项选择题(每小题有A,B,C,D四个选项,只有一个选项符合题目要求.) 1.只有支持HTTP1.1协议标准的"放置"功能.浏览器才能执行(B)操作. A.读取 B.写入 C. ...

  7. “科大讯飞杯”第十七届同济大学程序设计预选赛暨高校网络友谊赛 F.排列计算

    "科大讯飞杯"第十七届同济大学程序设计预选赛暨高校网络友谊赛 F.排列计算 题目链接 题目描述 天才程序员菜哭武和石头组队参加一个叫做国际排列计算竞赛 (International ...

  8. 华为杯数学建模2020什么时候出结果_关于组织参加“华为杯”第十七届中国研究生数学建模竞赛通知...

    亲爱的NNUers 2020年大家期待已久的 "华为杯"第十七届中国研究生数学建模竞赛 重磅来袭 遇见"华为杯" "华为杯"第十七届中国研究 ...

  9. “统信杯” 第十七届黑龙江省大学生程序设计竞赛

    "统信杯" 第十七届黑龙江省大学生程序设计竞赛 前言 题目 A. Bookshelf Filling C. Tree Division D. Collision Detector ...

最新文章

  1. 【CVPR2022】基于鲁棒区域特征生成的零样本目标检测
  2. Python基础(1) - 初识Python
  3. MySQL-主从架构的搭建
  4. 下学期计算机教学工作计划,初中信息技术下学期教学工作计划
  5. 【计算机网络复习】1.1.3 速率相关的性能指标
  6. 用nohup执行python程序时,print无法输出
  7. 排序算法(二)--选择排序法
  8. 播放视频时有残影、水纹的原因
  9. windows驱动安装卸载的实用小工具-InstDrv.exe
  10. oracle数字进一函数,oracle常用函数一:数字函数
  11. springboot内存占用过高问题排查 - jvm内存使用分析
  12. 百分点数据科学实验室:产品生命周期管理创新应用落地实践
  13. You Dont Know JS 中文版
  14. 常见几个排序源码及二分查找源码
  15. C程序中各个段的含义
  16. 聚合支付排名前十的平台有哪些?
  17. LASSO近端梯度下降法Proximal Gradient Descent公式推导及代码
  18. iphone计算机照片大小,如何在iPhone上调整照片尺寸-缩小照片以缩小
  19. php 小程序即时聊天,小程序组件:聊天会话组件的介绍(附代码)
  20. 13.ListView和GridView

热门文章

  1. 读《九败一胜—美团创始人王兴创业十年》有感
  2. C语言源文件名为什么无效,c语言源程序常错误分类及其改错.doc
  3. 研究ffmepg中有感(NDK 与 JNI 的关系)
  4. 为什么推荐做印尼tiktok账号运营?
  5. JavaScript(三)
  6. 幻影虚拟位置破解版连接不到服务器,ffbe幻影战争与服务器连接失败怎么办
  7. 2019年20个最佳产品信息管理(PIM)软件(一)
  8. MySQL5.7自带分词搜索使用
  9. Visual Studio 2022 的下载
  10. Linux常用命令整理(适合初学)