【jzoj】2018.1.30NOIP普及组——模拟赛D组

@_@

前言

写博客时间 2018/1/30 22:36。
感想:出数据的dalao我服!

正题


题目1:二项式展开式(jzoj2254)

输入一个整数,求展开(a+b)^n。展开方式为 (a+b)^n=?a^n+?a^(n-1)b+?a^(n-2)b^2+…+?b^n
其中” ? “为系数。如果系数为 1,则需要省略系数;如果次数为 1,则需要省略次数;如果次数为 0,则需要省略;如果系数为 0,则需要省略这一项。注意:前面(a+b)^n 的次数n是必有的。
来自纪中网站
这里求组合我用的是杨辉三角。


样例输入

样例输入1

3

样例输入2

5

样例输出

样例输出1

(a+b)^3=a^3+3a^2b+3ab^2+b^3

样例输出2

(a+b)^5=a^5+5a^4b+10a^3b^2+10a^2b^3+5ab^4+b^5


代码

#include<cstdio>
using namespace std;
int n;
unsigned long long f[67][67];
int main()
{//freopen("power.in","r",stdin);//freopen("power.out","w",stdout);scanf("%d",&n);if (n==1) {printf("(a+b)^1=a+b");return 0;}//特殊情况if (n==2) {printf("(a+b)^2=a^2+2ab+b^2");return 0;}//特殊情况f[0][0]=1;for (int i=1;i<=n;i++){f[i][0]=1;for (int j=1;j<=n;j++){f[i][j]=f[i-1][j]+f[i-1][j-1];}}//杨辉三角printf("(a+b)^%d=",n);//开头输出for (int i=0;i<=n;i++){if (i==0) printf("a^%d",n);//头else if (i==1) printf("%da^%db",n,n-1);else if (i==n-1) printf("%dab^%d",n,n-1);else if (i!=n) printf("%llda^%db^%d",f[n][i],n-i,i);//输出不解释if (i!=n) printf("+");//加号if (i==n) printf("b^%d",n);//尾}
}

题目2:溜冰(jzoj2255)

一个冰道,长L,有N个转弯点。每个转弯点限速S[i],距离起点D[i]米处。每一米速度可以加1或减1。求这条道能加速到的最快速度。
From jzoj
因此最快速度是5。


输入

第一行两个整数L和N。
第二行到第N+1行:第i+1行表示第i个转弯处的两个参数D[i],S[i]。

输出

输出仅一行,一个整数表示滑行过程中的最大速度(包括起点和终点的速度)。

样例输入

14 3
11 1
7 3
13 8

样例输出

5


首先为了方便处理,我们先根据距离进行一次快排。
我们不难发现这冰道有3种情况。

1.从一个点无论如何加速都无法到达下一个的最大限速,如图:From jzoj
这里我们就不停加速就是 s[i]=s[i-1]+d[i]-d[i-1] ans=max(ans,s[i])
2.
From jzoj
那我们先假设距离第一个点x米前减速,之后加速。那我们可以推一下x是前一段距离,s[i]+x是加速到达的高度,s[i]+x-s[i+1]是需要减速的距离,用两段距离加起来就是它们之间的长度也就是x+s[i]+x-s[i+1]=d[i+1]-d[i],然后就可以推出 x=(s[i]+s[i+1]+d[i])/2。

3.
From jzoj
如果到达前一个点的最大限速,就算不停减速也到不了下一个点的最大限速,那我们只能提前到推一遍推出新的最大限速。就算:s[i-1]=s[i]+d[i]-d[i-1]


代码

#include<cstdio>
#include<algorithm>
using namespace std;
struct point{int x,w;
};//结构体,快排用
point a[100001];
int sp,l,ll,nsp,n,s;
bool cmp(point dx,point dy)
{return dx.x<dy.x;
}//快排函数
int main()
{//freopen("skate.in","r",stdin);//freopen("skate.out","w",stdout);scanf("%d %d",&l,&n);for (int i=1;i<=n;i++){   scanf("%d%d",&a[i].x,&a[i].w);}//输入sort(a+1,a+n+1,cmp);//排序for (int i=n;i>=1;i--){a[i-1]=min(a[i-1].w,a[i].w+a[i].x-a[i-1].x);//第三种情况}a[0].w=1;//起点速度为1for (int i=1;i<=n;i++){ll=a[i].x-a[i-1].x;//距离if (a[i].w>a[i-1].w){if (a[i-1].w+ll<=a[i].w) {a[i].w=a[i-1].w+ll;s=max(a[i].w,s);}//第一种情况else {s=max(s,(int)(a[i].w+a[i-1].w+ll)/2);}//第二种}else {s=max(s,(int)(a[i].w+a[i-1].w+ll)/2);}//第二种}s=max(s,a[n].w+l-a[n].x);//终点前的加速printf("%d",s);//输出
}

题目3:方案数(jzoj2256)

有N个人,无数块黑白巧克力。其中每个人只能拿一种巧克力,至少c个人拿了巧克力。接下来2行,分别表示每个同学最多拿黑巧克力的个数和最多拿白巧克力的个数。输出他们拿巧克力的方案数%10007。


样例输入

样例输入1

2 2
1 1
1 1

样例输入2

2 2
2 2
2 3

样例输出

样例输出1

1

样例输出2

4


我们用f[i][j]来表示前i个人拿了j个巧克力的方案数,然后把f[i][c+1]+f[i][c+2]+f[i][c+3]…都合并到f[i][c]那里。动态转移方程:
f[i][j]=f[i-1][j]*b[i] + f[i-1][j-1]*a[i](j!=c)
f[i][j]=f[i-1][j](a[i]+b[i]) + f[i-1][j-1]a[i] (j=c)
f[i-1][j]*b[i]表示白巧克力
f[i-1][j-1]*a[i]表示黑巧克力
f[i-1][j-1]*a[i]表示已经到达或超过20个人选的黑巧克力


#include<cstdio>
#include<iostream>
using namespace std;
int f[100001][21],n,c,bl[100001],wh[100001],s;
int main()
{//freopen("fas.in","r",stdin);//freopen("fas.out","w",stdout);scanf("%d%d",&n,&c);s=1;f[0][0]=1;//初始化for (int i=1;i<=n;i++){scanf("%d",&bl[i]);bl[i]%=10007;}for (int i=1;i<=n;i++){scanf("%d",&wh[i]);wh[i]%=10007;f[i][0]=(f[i-1][0]*(wh[i]%10007))%10007;//初始化2}for (int i=1;i<=n;i++){for (int j=1;j<=c;j++){if (j<c) f[i][j]+=(f[i-1][j]*wh[i]%10007+f[i-1][j-1]*bl[i]%10007)%10007;else f[i][j]+=((f[i-1][j]*((wh[i]+bl[i])%10007))%10007+(f[i-1][j-1]*bl[i])%10007)%10007;//动态转移}}printf("%d",f[n][c]);//输出
}

题目4:小L(jzoj2257)

给你N个数对(a[i], b[i]),计算函数
From jzoj
函数y四舍五入取整。
将N个数对去掉其中的K个后计算一个新的y值,均能满足y ≤ λ,求最小的λ 值。


输入

输入包含多组数据,每组测试数据包含:
第一行两个整数N和 K;
第二行为N个数:a[1] a[2] … a[n]
第三行为N个数:b[1] b[2] … b[n]
当N、K均为0时输入结束。

输出

对应每组数据输出一行,即找到的最小的λ值。

样例输入

3 1
5 0 1
5 1 6
4 2
1 2 7 9
5 6 7 9
0 0

样例输出

83
100


设函数值y的最小值为x,则:这里写图片描述
则:这里写图片描述
则:这里写图片描述
最后二分答案


代码

#include<cstdio>
#include<algorithm>
#include<cmath>
using namespace std;
long long n,k;
long long s,s1,s2,sa,sb,m1,m2,left,right;
struct point{long long n1,n2;long long c;
};
point a[10001];
bool cmp(point x,point y)
{return x.c>y.c;
}
bool ok(int x)
{long long s1=0,s2=0;for (int i=1;i<=n-k;i++){s1+=a[i].n1;s2+=a[i].n2;//累加}return round(100.0*s1/s2)>x;//四舍五入
}
int main()
{freopen("math.in","r",stdin);freopen("math.out","w",stdout);while (true){scanf("%d%d",&n,&k);if (n==0 && k==0) break;m2=(long long)1e18;sa=0;sb=0;m1=0;for (int i=1;i<=n;i++){scanf("%d",&a[i].n1);sa+=a[i].n1;m1=max(m1,(long long)a[i].n1);}for (int i=1;i<=n;i++){scanf("%d",&a[i].n2);sb+=a[i].n2;m2=min(m2,(long long)a[i].n2);}left=100*sa/sb;right=100*m1/m2;//确定范围while (left<=right)//二分答案{long long mid=(left+right)/2;for (int i=1;i<=n;i++) a[i].c=a[i].n1*100-mid*a[i].n2;//计算sort(a+1,a+1+n,cmp);//快排if (ok(mid)) left=mid+1;//判断else right=mid-1;}printf("%d\n",left);//输出}
}

后序

其实这后面是我第二天来写的,好了去做题了(^o^)/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/324882.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

开发人员也要懂点的测试知识

转载自 开发人员也要懂点的测试知识 本文来自于作者投稿&#xff0c;作者陈彩华&#xff0c;贝聊后端开发工程师。 最近参加了保利威测试总监李乐的《互联网测试姿势》为主题的分享交流会&#xff0c;收获颇丰&#xff0c;作为一个开放&#xff0c;秉承“不懂产品和测试的开…

转发和重定向

需求说明 用户输入并提交登录信息 登录成功&#xff0c;跳转到success.jsp页面 登录失败&#xff0c;跳转回login.jsp页面 理解图 区别详解

实现自己的.NET Core配置Provider之Yaml

YAML是一种更适合人阅读的文件格式&#xff0c;很多大型的项目像Ruby on Rails都选择YAML作为配置文件的格式。如果项目的配置很少&#xff0c;用JSON或YAML没有多大差别。看看rails项目中的配置文件&#xff0c;如果用JSON写试试什么感受吧。 在《实现自己的.NET Core配置Pro…

信息时代与人工智能时代的教育变革

求关注求转发本文是雄雄的小课堂投稿的第 1 篇文章&#xff0c;作者&#xff1a;小溪时代发展迅速&#xff0c;学校的教育体系却没有很大的改变。比如现在的学生们还是学着几百年前的东西。试想一下&#xff0c;这是否真的适合我们这个时代&#xff0c;亦或真的需要改变了。教育…

【jzoj】2018.1.31 NOIP普及组——D组模拟赛

前言 今天题目比较水and我进了C组&#xff0c;不过太太太太太太太太太太太太太太太太绝望了QAQ。所以我也没有做C组的题。写完博客我就做O(∩_∩)O。 正题 题1&#xff1a;奇数统计&#xff08;jzoj1547&#xff09; 就是输入n个数&#xff0c;输出出现次数为奇数的一个数&a…

RabbitMQ系列教程之四:路由(Routing)

在上一个教程中&#xff0c;我们构建了一个简单的日志系统&#xff0c;我们能够向许多消息接受者广播发送日志消息。在本教程中&#xff0c;我们将为其添加一项功能 &#xff0c;这个功能是我们将只订阅消息的一个子集成为可能。 例如&#xff0c;我们可以只将关键的错误消息输…

【jzoj3734,Usaco2014Open银组】双导航(gpsdual)

前言 这是今天C组的题&#xff0c;闲得无聊做了一会&#xff0c;结果就对了233。这算是学了SPFA之后的第一次实战了。反正其他C组题我也不想做了。好了现在bi~~&#xff08;系统自动屏蔽&#xff09;也在做这道题。 还有这道题的名字叫 正题 题目 一个有向图&#xff0c;有…

Java代码到底是如何编译成机器指令的。

转载自 Java代码到底是如何编译成机器指令的。 在《Java代码的编译与反编译》中&#xff0c;有过关于Java语言的编译和反编译的介绍。我们可以通过javac命令将Java程序的源代码编译成Java字节码&#xff0c;即我们常说的class文件。这是我们通常意义上理解的编译。 但是&am…

DDD理论学习系列(3)-- 限界上下文

1. 引言 限界上下文可以拆分为两个词&#xff0c;限界和上下文。限界&#xff1a;是指一个界限&#xff0c;具体的某一个范围。上下文&#xff1a;个人理解就是语境。 比如我们常说的段子&#xff1a; “我想静静。”这个句子一般是想表达“我想静一静”的意思。但是我们却把…

分布式事务解决方案——柔性事务与服务模式

转载自 分布式事务解决方案——柔性事务与服务模式 初识分布式系统 关于分布式一致性的探究 分布式系统的CAP理论&#xff08;需要到博客中查看&#xff09; 分布式系统的BASE理论&#xff08;需要到博客中查看&#xff09; Java中的事务——JDBC事务和JTA事务 Java中的…

“温室里的花朵”也要直面困难

求关注求转发本文是雄雄的小课堂投稿的第 2 篇文章&#xff0c;作者&#xff1a;小溪“花朵”在爸妈的细心培育下成长。可它们不知道未来是怎样的&#xff0c;它们对未来充满着想象与渴望&#xff0c;却没有人曾告诉它们&#xff0c;这个世界布满荆棘&#xff0c;而“花朵们”也…

Visual Studio 2015和2017里面应该创建哪种 Class Library

微软有些时候是一副不讲道理的大家长作风。一个例子就是它在 Visual Studio 2015/2017 里面配置了一大堆普通人没法理解的 Class Library 模板。 你真的知道应该选哪个吗&#xff1f; 这就是 VS2017 里面你可能熟悉的长列表&#xff08;而且因为我没有安装 UWP 开发项目&#…

win10操作技巧介绍,很实用!

求关注求转发本文是雄【雄的小课堂】原创的第 136 篇文章1.wind:返回桌面不管你当前所在的什么窗口&#xff0c;一键即可切换到桌面&#xff0c;有时候称之为“老板键”2.wine:打开计算机我最喜欢用了&#xff0c;不管你在任何窗口&#xff0c;一键打开计算机&#xff0c;相比去…

深入理解分布式系统中的缓存架构(上)

转载自 深入理解分布式系统中的缓存架构(上) 本文主要介绍大型分布式系统中缓存的相关理论&#xff0c;常见的缓存组件以及应用场景。 1 缓存概述 2 缓存的分类 缓存主要分为以下四类 2.1 CDN缓存 基本介绍 CDN(Content Delivery Network 内容分发网络)的基本原理是广泛…

微软向开发者推出区块链概念验证框架

微软在近期的一篇博文中宣布了一个新的框架&#xff0c;用以在Azure云平台上加速已通过企业概念验证&#xff08;PoC&#xff09;的区块链部署。微软希望用户能在可支持分布式账本&#xff08;DLT&#xff09;解决方案的基础设施上&#xff0c;借助于灵活的契约和更少的时间&am…

Cookie和Session 登录

Cookie 实现免登陆和Session 01、 需求说明 完成用户登录功能 登录成功后跳到成功页面,显示用户名 登录失败可以跳回登录页面 登录成功后后续操作均能显示当前登录的用户名 02、完成代码 DologinServlet.java Override protected void service(HttpServletRequest req, Http…

《给教师的阅读建议》经典语录

System.out.print("今天开始继续读书摘录"); //不知道官方让不让我在博客里面记录 //如果不让的话我可能得转到别的上面记录 System.out.print("现在开始看《给教师的阅读建议》"); System.out.println("今天是第1天&#xff01;也是最后一天");…

教你一招快速打开idea的秘诀

大家根据电脑系统的位数&#xff0c;选择 32 位的 VM 配置文件或者 64 位的 VM 配置文件32 位操作系统内存不会超过 4G&#xff0c;所以没有多大空间可以调整&#xff0c;建议不用调整了64 位操作系统中 8G 内存以下的机子或是静态页面开发者是无需修改的。64 位操作系统且内存…

深入理解分布式系统中的缓存架构(下)

转载自 深入理解分布式系统中的缓存架构(下) 承接上一篇《理解分布式系统中的缓存架构(上)》&#xff0c;介绍了大型分布式系统中缓存的相关理论&#xff0c;常见的缓存组件以及应用场景&#xff0c;本文主要介绍缓存架构设计常见问题以及解决方案&#xff0c;业界案例。 分…

【jzoj】2018.2.1 NOIP普及组——D组模拟赛

前言 懒… 正题 题1&#xff1a;牛车&#xff08;jzoj1390&#xff09; 有m条公路&#xff0c;有n头牛各开一辆车&#xff0c;如果有x辆车开在它前门&#xff0c;它速度就会降低d*x&#xff0c;路上速度至少为l。求有多少头牛可以上路。 输入 第1行: 4个空格隔开的整数N,M,…