Problem A: 余数

Time Limit: 1000 ms Memory Limit: 512 MB

Description

Input

Output

Sample Input
3 4
Sample Output
4

HINT

Solution

那个所谓\(\sqrt n\)的东西叫做整除分块。

显然对于\(n÷i\),当$i<=\sqrt n $时,每个i都有一种取法

当\(n>=i>\sqrt n\),i每加\(\sqrt n\),\(n÷i\)的值就+1

然后就可以根号时间复杂度求了。

#include<bits/stdc++.h>
using namespace std;
#define mod 1000000007
const unsigned long long inv2=5e8+4;
unsigned long long n,m,ans=0;
signed main(){scanf("%llu%llu",&n,&m);for(unsigned long long i=1,pos;i<=min(n,m);i=pos+1){pos=min((n/(n/i)),m);(ans+=n%mod*((pos-i+1)%mod)%mod-(i+pos)%mod*((pos-i+1)%mod)%mod*inv2%mod*((n/i)%mod)%mod+mod)%=mod;}if(m>n)(ans+=n%mod*((m-n)%mod)%mod)%=mod;printf("%llu\n",ans%mod);
}

Problem B: 糖果

Time Limit: 1000 ms Memory Limit: 512 MB

Description

Input

Output

Sample Input
5
8 7 4 8 3
4 2 5 3 7
Sample Output
3
1 4 5

HINT

Solution

把糖果们按照a值从大到小排序,然后先取第一个出来,之后的两两分组,每组取b值较大的一个

易证这样是满足要求的(是因为我不会严谨证明)

#include<bits/stdc++.h>
using namespace std;
int n;
struct qwq{int a,b;int id;
}a[200001];
bool cmp(qwq a,qwq b){return a.a>b.a;
}
bool vis[200001];
int main(){scanf("%d",&n);for(int i=1;i<=n;++i){scanf("%d",&a[i].a);}for(int i=1;i<=n;++i){scanf("%d",&a[i].b);a[i].id=i;}sort(a+1,a+1+n,cmp);for(int i=2;i<=n;i+=2){if(a[i].b>a[i+1].b)vis[i]=true;else vis[i+1]=true;}printf("%d\n",(n/2)+1);printf("%d ",a[1].id);for(int i=2;i<=n;++i){if(vis[i])printf("%d ",a[i].id);}
}

Problem C: 虫子

Time Limit: 2000 ms Memory Limit: 512 MB

Description

Input

Output

Sample Input
5
1 2 2 1
1 2 3 4 5
5
1 3 4
1 4 5
2 2 3
1 5 2
1 1 4
Sample Output
1.64
1.80
2.28
2.32
2.80
1.84

HINT

Solution

还不会,等我学了树剖再说。

转载于:https://www.cnblogs.com/youddjxd/p/11329556.html

noip2019集训测试赛(二)相关推荐

  1. [补档]noip2019集训测试赛(十二)

    Problem A: 记忆(memory) Time Limit: 1000 ms Memory Limit: 512 MB Description 你在跟朋友玩一个记忆游戏. 朋友首先给你看了n个长 ...

  2. [补档]noip2019集训测试赛(十五)

    Problem A: 传送带 Time Limit: 1000 ms Memory Limit: 256 MB Description 在一个二维平面上有两条传送带,每一条传送带可以看成是一条线段.两 ...

  3. noip2019集训测试赛(五)

    Problem A: lcm Time Limit: 1000 ms Memory Limit: 256 MB Sample Input 3 1 2 5 Sample Output 1 4 55 HI ...

  4. [补档]noip2019集训测试赛(九)

    因为这次考试我一道题都不会,所以先不写了 转载于:https://www.cnblogs.com/youddjxd/p/11442143.html

  5. [补档]noip2019集训测试赛(八)

    Problem B: 2048 Special Judge Time Limit: 1000 ms Memory Limit: 256 MB Description 2048曾经是一款风靡全球的小游戏 ...

  6. [补档]noip2019集训测试赛(十)

    Problem A: fibonacci Time Limit: 2000 ms Memory Limit: 256 MB Description 小y最近迷上了fibonacci数列,他定义了一种数 ...

  7. [补档]noip2019集训测试赛(十三)

    Problem A: Fairy Time Limit: 1000 ms Memory Limit: 256 MB Description 给定n个点,m条边的无向图(无自环),可以从图中删除一条边, ...

  8. [补档]noip2019集训测试赛(十四)

    Problem A: Fibonacci(fib.pas/cpp) Time Limit: 1000 ms Memory Limit: 128 MB Description 豆豆最近迷上了Fibona ...

  9. noip2019集训测试赛(七)

    Problem A: Maze Time Limit: 1000 ms Memory Limit: 256 MB Description 考虑一个N×M的网格,每个网格要么是空的,要么是障碍物.整个网 ...

  10. 2016集训测试赛(二十六)Problem A: bar

    Solution 首先审清题意, 这里要求的是子串而不是子序列... 我们考虑用1表示p, -1表示j. 用sum[i]表示字符串前\(i\)的前缀和. 则我们考虑一个字符串\([L, R]\)有什么 ...

最新文章

  1. tomcat下面web应用发布路径配置 ( 即虚拟目录配置 )
  2. php写账户冻结_线上开户指南(首次入金2万,账户总净资产不得低于1万,交易佣金万三,最低25,合单,没平台费)入金后才会有账户号...
  3. jQuery的DOM操作之取值/赋值(1)
  4. Android自己主动化測试之Monkeyrunner用法及实例
  5. windows MySQL 5+ 服务手动安装
  6. asp.net接受表单验证格式后再提交数据_看滴普科技大前端如何玩转el-form-renderer 表单渲染器1.14.0
  7. 增强火山图,要不要试一下?
  8. python语言程序设计编程题_Python语言程序设计(测试练习题)
  9. 在 Windows 下远程桌面连接 Linux - XManager 篇
  10. JVM常见面试题及详解
  11. a modern epidemic
  12. Python v / s PHP:2019年选择哪种编程语言?
  13. html5调整文字段落之间的距离,css设置p段落上下间距距离
  14. SDN的深入思考(1):SDN的核心本质到底是什么?
  15. 雷电模拟器 + Xposed框架 + 北京消费券
  16. 【JAVA 学习笔记】HashMap 探究
  17. 华宇智能数据官网全新上线,赋能行业数字化转型
  18. 对一次微信升级事件的自我反省:思维方式决定解决问题能力
  19. IIS的安装、配置与测试
  20. 离散数学/组合数学:利用容斥原理,求满射函数的个数,注意它容斥原理求得的是”非满射函数的个数”,以在A到B形成的函数的总个数为“全集“求该全集中”非满射函数的个数”的补集才是目标个数。

热门文章

  1. 午休,要有午休床,也要有毛毯
  2. MAC编译:fatal error: ‘endian.h‘ file not found
  3. JDK GUI对应的c文件
  4. IDEA配置TeaVM插件
  5. 脚本都不写,不能算正式测试
  6. GetUserName()第二个参数中指明缓冲区长度
  7. linux rpm安装简要说明
  8. CreateProcess()无法启动应用?
  9. 某项目中,doubango与NAT服务器的冲突
  10. 查看一个进程的线程情况