A. 丁神去谷歌 2014新生暑假个人排位赛02

时间限制 1000 ms 内存限制 65536
KB

题目描述

丁神要去Google上班了,去之前丁神想再做一道水题,但时间不多了,所以他希望题目做起来既水又快。现在一共有n道题,编号从1到n,每道题有两个值a和b,a为做这道题需要的时间,b为题目的“水值”,丁神希望做b/a最大的那题。

输入格式

输入第一行为数据组数T(T≤10),接下来T组数据,每组数据中第一行为一个数n,n为题目的数量,接下来n行,每行两个正整数a和b。如果两道题b/a的值是一样的就输出a比较小的,如果还一样就输出编号比较靠前的。 1≤a,b≤109,1≤n≤100000)

输出格式

对于每组数据,输出对应的题目编号,每个输出占一行。

输入样例

1
2
3 5
4 8

输出样例

2

水题不解释,数据颇大,不能排序,卡在cin,5次

#include <cstdio>
#include <algorithm>
#include <cstring>
#include <queue>
#include <cmath>
#include <vector>
using namespace std;
const double eps=10e-7;
int main(){
ios::sync_with_stdio(false);
int t;
cin>>t;
while(t--){
int n;
cin>>n;
double maxd=0;
int a,b;
int mina;
int ans;
for(int ni=1;ni<=n;ni++){
cin>>a>>b;
if(maxd<b/a){
maxd=b/a;
mina=a;
ans=ni;
}
else if(fabs(maxd-b/a)<eps){
if(a<mina){
mina=a;
ans=ni;
}
}
}
cout<<ans<<endl;
}
return 0;
}

B. 丁神又去谷歌 2014新生暑假个人排位赛02

时间限制 1000 ms 内存限制 65536
KB

题目描述

丁神又要去Google上班了,这一次丁神想多做几道水题,并使题目的总水量最大.丁神同一时刻只能在水一道题,只有做完这道题才能得到它的水值,丁神的总时间为t,现在一共有n道题,编号从1到n,每道题有两个值a和b,a为做这道题需要的时间,b为题目的水值。

输入格式

输入第一行为数据组数T(T≤10),接下来T组数据,每组数据中第一行为两个数t和n,n为题目的数量,t为总时间,接下来n行,每行两个正整数a和b。(1≤a,t≤1000,1≤n≤100,1≤b≤1000000000)

输出格式

对于每组数据,输出对应的最大总水量,每个输出占一行。

输入样例

1
10 2
8 16
6 12

输出样例

16

咳咳..其实我第一次的时候交的贪心我会说吗?看来dp还是意识缺乏,简单的01背包

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <queue>
#include <cmath>
#include <vector>
using namespace std; class query{
public:
int a,b,index;
};
bool cmp(query q1,query q2){
long long i=(q1.b*q2.a)-(q2.b*q1.a);
if(i>0)return true;
if(i<0)return false;
if(q1.a>q2.a)return true;
if(q1.a<q2.a)return false;
if(q1.index<q2.index)return true;
return false;
}
query que[120];
long long dp[120][1200];
int main(){
int t;
ios::sync_with_stdio(false);
cin>>t;
//cout<<t<<endl;
while(t--){
int n,time;
cin>>time>>n;
int a,b;
for(int ni=0;ni<n;ni++){
cin>>a>>b;
que[ni].a=a;
que[ni].b=b;
que[ni].index=ni;
}
// for(int ni=0;ni<n;ni++){
// cout<<que[ni].a<<" "<<que[ni].b<<" "<<que[ni].index<<endl;
//}
sort(que,que+n,cmp);
long long ans=0;
// for(int ni=0;ni<n;ni++){
// cout<<que[ni].a<<" "<<que[ni].b<<" "<<que[ni].index<<endl;
// }
memset(dp,0,sizeof(dp));
dp[0][que[0].a]=que[0].b;
for(int i=0;i<n;i++){
for(int j=1;j<=time;j++){
dp[i][j]=max(dp[i][j],dp[i][j-1]);
if(i)dp[i][j]=max(dp[i][j],dp[i-1][j]);
if(i&&j>=que[i].a){
dp[i][j]=max(dp[i][j],dp[i-1][j-que[i].a]+que[i].b);
}
//cout<<"dp"<<i<<" "<<j<<" "<<dp[i][j]<<endl;
}
}
cout<<dp[n-1][time]<<endl;
}
return 0;
}

c:

C. goblin 2014新生暑假个人排位赛02

时间限制 1000 ms 内存限制 65536
KB

题目描述

现有一段横向长度为N的山脉,其中每段有一个独一无二的高度Hi(1到N之间的正整数)。现在你想知道对于长度为N的山脉,可能有这样的山脉多少种。这样的山脉是:某个位置要么比两边的高度都低,要么比两边的高度都高。两座山脉 A和 B 不同当且仅当存在一个 i,使得 Ai≠Bi。由于这个数目可能很大,你只对它除以 P 的余数感兴趣。

输入格式

输入以EOF为结束,每组仅含一行,两个正整数 N, P。 3≤N≤4200,P≤10^9

输出格式

对于每组数据输出仅含一行,一个非负整数,表示你所求的答案对 P 取余之后的结果。

输入样例

4 7

输出样例

3
说明:共有 10 种可能的山脉,它们是:
1324 1423 2143 2314 2413
3142 3241 3412 4132 4231

又是dp

又没找出关系

...........

总之就是好好思考...

对k+1选取k+1作为基点,它在哪段都会成为最大点,上顶点,

设左边长度j:

左边 ans[j]

右边 ans[k-j]

ans(k+1)=SUM(c[j][k]*ans[j]*ans[k-j])

ym吴大神,刘大神

接下来注意不要爆运算中的int就行了(改成longlong)

#include <iostream>
using namespace std;
#define MAXN 4202
int c[MAXN][MAXN];
long long ans[MAXN];
int main(){
int n,p;
while(cin>>n>>p){
c[1][1]=c[1][0]=1;
for(int i=2;i<=n;i++){
c[i][0]=1;
for(int j=1;j<=i;j++){
c[i][j]=(c[i-1][j-1]+c[i-1][j])%p;
}
}
ans[0]=1%p;
ans[1]=1%p;
ans[2]=1%p;
ans[3]=2%p;
for(int i=4;i<=n;i++){
for(int j=0;j<i;j+=2){
ans[i]=ans[i]%p+((c[i-1][j])*(ans[i-1-j])%p*ans[j])%p;
ans[i]%=p;
}
}
cout<<ans[n]*2%p<<endl;
}
}

北邮新生排位赛2解题报告a-c的更多相关文章

  1. 北邮新生排位赛1解题报告d-e

    话说cdsn要是前面插入源代码又什么都不放就会出现奇怪的源代码?不知道是哪个网页的 407. BLOCKS 时间限制 1000 ms 内存限制 65536 KB 题目描述 给定一个N∗M的矩阵,求问里 ...

  2. 北邮新生排位赛1解题报告a-c

    <div class="page-header" style="padding-bottom: 9px; margin: 20px 0px 30px; border ...

  3. 北邮新生排位赛2解题报告d-e

    <> 427. 学姐逗学弟 时间限制 3000 ms 内存限制 131072 KB 题目描述 学弟们来了之后,学姐每天都非常高兴的和学弟一起玩耍.这一天,学姐想出了这样一个游戏,她画了一棵 ...

  4. 2014北邮新生归来赛解题报告a-c

    <span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255) ...

  5. 2014北邮新生归来赛解题报告d-e

    D: 399. Who Is Joyful 时间限制 3000 ms 内存限制 65536 KB 题目描述 There are several little buddies standing in a ...

  6. SCNU ACM 2016新生赛决赛 解题报告

    新生初赛题目.解题思路.参考代码一览 A. 拒绝虐狗 Problem Description CZJ 去排队打饭的时候看到前面有几对情侣秀恩爱,作为单身狗的 CZJ 表示很难受. 现在给出一个字符串代 ...

  7. SCNU ACM 2016新生赛初赛 解题报告

    新生初赛题目.解题思路.参考代码一览 1001. 无聊的日常 Problem Description 两位小朋友小A和小B无聊时玩了个游戏,在限定时间内说出一排数字,那边说出的数大就赢,你的工作是帮他 ...

  8. 2017.7.15清北夏令营精英班Day1解题报告

    成绩: 预计分数:20+10+40 实际分数:100+10+40. 一百三十多人的比赛全场rand7还水了个鼠标+键盘 unbelievable! 考试题目链接: https://www.luogu. ...

  9. LeetCode解题报告:Linked List Cycle && Linked List Cycle II

    LeetCode解题报告:Linked List Cycle && Linked List Cycle II 1题目 Linked List Cycle Given a linked ...

随机推荐

  1. Anroid 搭建Maven私服(Android Studio)

    一.场景 ① 公司中有多个项目,多人开发,开发中的某一模块需要被其他几个项目的模块所依赖,最简单粗暴的方式就是打包成aar或者jar文件逐个拷贝到libs下进行依赖,可是这种方式太过于麻烦,而且需要每 ...

  2. Codeforces 1006 F - Xor-Paths

    F - Xor-Path 思路: 双向搜索dfs 如果普通的搜索复杂度是n 那么双向搜索复杂度是√n 代码: #include<bits/stdc++.h> using namespace ...

  3. tchart example

    Random random = new Random(); // Color SeriesColor; int SeriesIndex=0; tChart1.Series.Clear(); Steem ...

  4. ubuntu16.04+cuda8.0+gpu

    安装完ubuntu系统之后,在学校的环境下,联网需要安装mentohust. 参考: http://www.cnblogs.com/alexanderkun/p/6905604.html http:/ ...

  5. maven---->配置,指令,插件,使用

    maven是用于java的自动化构建工具. 1.下载:http://maven.apache.org/download.cgi 下载下面截图标红处的文件 然后直接解压可以得到文件夹,得到如下文件夹 不 ...

  6. WCF利用Stream上传大文件

    WCF利用Stream上传大文件 转自别人的文章,学习这个例子,基本上wcf也算入门了,接口用法.系统配置都有了 本文展示了在asp.net中利用wcf的stream方式传输大文件,解决了大文件上传问 ...

  7. Myeclipse项目中Source、Projects、Libraries、Order and export含义

    Myeclipse 新建一个项目时,会出现如下界面 输入项目名,点击next Source source folder:存放.java源文件的根目录:output folder:.class编译输出的 ...

  8. 2.7 UML状态图

    问题的引出 顺序图是对对象的动态行为进行建模,有多个对象的参与.协作 问题: 当需要考察单个实体的动态行为时, 用UML如何来建模呢? 什么是单个实体:一个软件系统?一个子系统?一个模块.一个构件? ...

  9. 创建gitlab ssh 密钥

    SSH代表用于管理网络,操作系统和配置的Secure Shell或Secure Socket Shell,并且每次都不需要使用用户名和密码即可验证GitLab服务器. 您可以设置SSH密钥以提供计算机 ...

  10. 『Python × C++』函数传参机制学习以及对比

    一.Python函数传参 在python中,函数传参实际上传入的是变量的别名,由于python内在的变量机制(名称和变量值相互独立),只要传入的变量不可变(tuple中的元素也要是不可变的才行),那么 ...