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

前言

今天题目比较水and我进了C组,不过太太太太太太太太太太太太太太太太绝望了QAQ。所以我也没有做C组的题。写完博客我就做O(∩_∩)O。

正题


题1:奇数统计(jzoj1547)

就是输入n个数,输出出现次数为奇数的一个数(只有一个)。


输入

第一行是N,下一行有N个正整数。

输出

出现了奇数次的数。

样例输入

9
3 1 2 2 17 1 3 17 3

样例输出

3


桶不解释


代码

#include<cstdio>
#include<iostream>
using namespace std;
int n,a[10001],x,ans;
int main()
{//freopen("count.in","r",stdin);//freopen("count.out","w",stdout);scanf("%d",&n);for (int i=1;i<=n;i++){scanf("%d",&x);a[x]++;}   for (int i=1;i<=10000;i++) if (a[i]%2==1) {printf("%d",i);return 0;}
}

相信我不加批注你们也懂不O(∩_∩)O


题2:有理逼近(jzoj1548)

From jzoj


输入

输入文件的第一行为P、N,其中 P、N<30000。

输出

输出文件只有一行,格式为“X/Y U/V”。注意,答案必须是既约的,也就是说分子、分母的最大公约数必须等于1。

样例输入

2 5

样例输出

4/3 3/2


暴枚好像会超时,所以我们先枚举分子,然后从中间开始向两边扩展的搜分母。
在这里感谢朋友提供思路,这里是他的博客:http://blog.csdn.net/sugar_free_mint


代码

#include<cstdio>
#include<cmath>
#include<iostream>
#include<algorithm>
using namespace std;
double p,s1,s2,ss1,ss2,j,k;
int w,n,u;
int main()
{//freopen("rational.in","r",stdin);//freopen("rational.out","w",stdout);scanf("%d%d",&w,&n);p=sqrt(w);//开方u=n/p;//确定中间值s1=-214748364;s2=1;ss1=214748364;ss2=1;//初始化for (double i=1;i<=n;i++){j=u;k=0;while (j+k<=n && j-k>=1){if (p-i/(j+k)>0 && p-i/(j+k)<p-s1/s2)//判断{s1=i;s2=(j+k);}if (p-i/(j-k)>0 && p-i/(j-k)<p-s1/s2){s1=i;s2=(j-k);}if (i/(j+k)-p>0 && i/(j+k)-p<ss1/ss2-p){ss1=i;ss2=(j+k);}if (i/(j-k)-p>0 && i/(j-k)-p<ss1/ss2-p){ss1=i;ss2=(j-k);}k++;}//扩展}s1=int(int(s1)/__gcd(int(s1),int(s2)));s2=int(int(s2)/__gcd(int(s1),int(s2)));//约分ss1=int(int(ss1)/__gcd(int(ss1),int(ss2)));ss2=int(int(ss2)/__gcd(int(ss1),int(ss2)));//约分printf("%.lf/%.lf %.lf/%.lf",s1,s2,ss1,ss2);//输出
}

题目3:活动安排(jzoj1549)

有n (n<=100) 个活动,每个活动开始时间si,结束时间fi。每个活动需要一个会场,求需要的最小会场数。水题。


输入

第一行是活动数n(1≤n≤100)。
以后的n行,每行两个整数,分别表示n个活动的开始时间si和结束时间fi(1≤i≤n),si

输出

一个整数,表示需要的最少会场数。

样例输入

4
1 8
2 5
7 15
5 9

样例输出

3


判断当前有没有空的会场,如果有就把活动安排进去,不然就开一个新的。


代码

#include<cstdio>
using namespace std;
int s[101],f[101],n,t,w,wf[101];
int main()
{//freopen("meet.in","r",stdin);//freopen("meet.out","w",stdout);scanf("%d",&n);for (int i=1;i<=n;i++) scanf("%d%d",&s[i],&f[i]);for (int i=1;i<n;i++)for (int j=i+1;j<=n;j++)if (s[i]>s[j]){t=s[i];s[i]=s[j];s[j]=t;t=f[i];f[i]=f[j];f[j]=t;}//看我连快排都懒得用了for (int i=1;i<=n;i++){for (int j=1;j<=w;j++)if (s[i]>=wf[j])//有空会场{wf[j]=f[i];f[i]=-1;break;}if (f[i]!=-1)//安排新会场{w++;wf[w]=f[i];//活动结束时间}}printf("%d",w);//输出
}

题目4:最小步数(jzoj1550)

一条路长n,每走到一个格会获得Ai元(-10000<=Ai<=10000),你也可以选择花100元跳过该格,金币不可以为负数。求到终点最小的步数


输入

共有两行。
第一行为整数N(0<=N<=100)。
第二行有N个整数,第K个数为A[K],-10000<=A[K]<=10000,。

输出

一个整数,表示需要走的最少步数。若无法走到终点,输出-1。

样例输入

6
30 30 30 30 30 30

样例输出

5


这里dp,其实记搜也可以过(不过不重要)。然后用f[i][j]来表示到达第i格用j步并且最后一步是过的最大金币,然后用f[i][j]来表示到达第i格用j步并且最后一步是过的最大金币。
动态转移方程:f[i][j]=max(f[i-1][j],f2[i-1][j])-100 (跳过该步)
f2[i][j]=max(f[i-1][j-1],f2[i-1][j-1])+a[i] (走过该步)


代码

#include<cstdio>
#include<iostream>
using namespace std;
int a[101],f[101][101],n,ans,f2[101][101];
int main()
{//freopen("steps.in","r",stdin);//freopen("steps.out","w",stdout);scanf("%d",&n);for (int i=1;i<=n;i++){scanf("%d",&a[i]);}   for (int i=1;i<=n;i++)for (int j=0;j<=i;j++) {f2[i][j]=-214748364;f[i][j]=-214748364;}//初始化 for (int i=1;i<=n;i++){for (int j=1;j<=i;j++){if (max(f[i-1][j],f2[i-1][j])-100>=0 && i!=n) f[i][j]=max(f[i-1][j],f2[i-1][j])-100;//跳if (max(f[i-1][j-1],f2[i-1][j-1])+a[i]>=0) f2[i][j]=max(f[i-1][j-1],f2[i-1][j-1])+a[i];//走}}for (int i=0;i<=n;i++) if (f2[n][i]>=0) {printf("%d",i);return 0;}//查找printf("-1");//不能到达
}

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

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

相关文章

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,…

JSP的四大作用域和九大内置对象

JSP的四大作用域和九大内置对象 https://wenku.baidu.com/view/a0974190152ded630b1c59eef8c75fbfc77d949d?ivk_sa1023194j&bfetypenew

事件总线知多少(2)

1.引言 之前的一篇文章事件总线知多少&#xff08;1&#xff09;&#xff0c;介绍了什么是事件总线&#xff0c;并通过发布订阅模式一步一步的分析重构&#xff0c;形成了事件总线的Alpha版本&#xff0c;这篇文章也得到了大家的肯定和积极的反馈和建议&#xff0c;在此谢谢大…

记录程序人生2020.8.11

1.晚休的时间总是短暂的&#xff0c;甚至你都没有来得及闭眼呢就需要将它睁开。上眼皮与下眼皮一直恋恋不舍的分开&#xff0c;天花板渐渐的呈现出来&#xff0c;该起了&#xff01; 2.5点一刻准时坐在外面的水泥台阶上&#xff0c;飞速打开屏幕中的背单词软件&#xff0c;%……

DDD理论学习系列(4)-- 领域模型

1.引言 我们还是先来拆词理解&#xff0c;领域模型可以拆为“领域”和“模型”二词。 领域&#xff1a;按照我们之前的文章的理解&#xff0c;DDD中的领域是指软件系统要解决的问题&#xff0c;如我们的办公设备公众号在线商城就是为了解决电商问题&#xff0c;对应的就是电商…

Ajax判断用户名是否可用

Ajax的简介 01展示效果并认识Ajax 方案1&#xff1a;传统方案 提交表单&#xff0c;服务器端处理&#xff0c;错误后跳转到注册页面&#xff0c;同时显示错误信息。返回客户端的是整个注册页面。 缺点&#xff1a;较大的网络流量&#xff0c;用户体验不好 方案2&#xff1a;使…