10.25 noip模拟试题
今天题目略水2333
依旧不粘题目了23333
T1
/*数学题 给定n个斜率 求有多少个三元组 保证两两斜率不同
ans=C(n,3)-ΣC(len[i],2)*(n-len[i])-ΣC(len[i],3)*/
#include<iostream>
#include<cstdio>
#include<algorithm>
#define inf 1e10
#define ll long long
#define maxn 300010
using namespace std;
ll n,a,b,c,ans,len[maxn],cnt;
struct node{
double k;
ll C;
}p[maxn];
ll init(){
ll x=,f=;char s=getchar();
while(s<''||s>''){if(s=='-')f=-;s=getchar();}
while(s>=''&&s<=''){x=x*+s-'';s=getchar();}
return x*f;
}
ll cmp(const node &x,const node &y){
return (x.k==y.k&&x.C<y.C)||x.k<y.k;
}
void Insert(ll x,ll y,ll z,ll o){
double K;
if(y==)K=inf;
else K=-double(x)/double(y);
p[o].C=z;p[o].k=K;
}
ll Cu(ll x,ll y){
if(y==)return x*(x-)/;
if(y==)return x*(x-)*(x-)/;
}
int main()
{
//freopen("trokuti.in","r",stdin);
//freopen("trokuti.out","w",stdout);
n=init();
for(ll i=;i<=n;i++){
a=init();b=init();c=init();
Insert(a,b,c,i);
}
sort(p+,p++n,cmp);
double now=p[].k;
ll nowc=p[].C;len[++cnt]++;
for(ll i=;i<=n;i++){
if(p[i].k==now&&p[i].C!=nowc){
nowc=p[i].C;len[cnt]++;
}
else if(p[i].k!=now){
len[++cnt]++;
now=p[i].k;nowc=p[i].C;
}
}
ans=n*(n-)*(n-)/;
for(ll i=;i<=cnt;i++){
if(len[i]>=)ans-=Cu(len[i],)*(n-len[i]);
if(len[i]>=)ans-=Cu(len[i],);
}
cout<<ans<<endl;
return ;
}
T2/*可贪心 或者一边nlogn的LIS */
#include<cstdio>
#include<algorithm>
#define maxn 100010
using namespace std;
int n,a[maxn],c[maxn],num;
int init(){
int x=,f=;char s=getchar();
while(s<''||s>''){if(s=='-')f=-;s=getchar();}
while(s>=''&&s<=''){x=x*+s-'';s=getchar();}
return x*f;
}
int main()
{
freopen("manage.in","r",stdin);
freopen("manage.out","w",stdout);
n=init();
for(int i=;i<=n;i++)
a[i]=init();
for(int i=;i<=n;i++){
int x=a[i];
if(x>c[num]){
c[++num]=x;continue;
}
int pos=lower_bound(c+,c++num,x)-c;
c[pos]=x;
}
printf("%d\n",num);
return ;
}
T3/*暴力 枚举最大的能用的s 然后将合法的边按g为关键字MST m*m*logm +剪枝50分*/
#include<iostream>
#include<cstdio>
#include<algorithm>
#define ll long long
#define maxn 410
#define maxm 50010
#define inf 1e18
using namespace std;
ll n,m,S,G,ms,mg,cnt,tot,fa[maxn],falg;
ll ans=inf*,mx,mig=inf;
struct node{
ll u,v,s,g;
}p[maxm];
struct edge{
ll u,v,o,g;
}e[maxm];
ll init(){
ll x=,f=;char s=getchar();
while(s<''||s>''){if(s=='-')f=-;s=getchar();}
while(s>=''&&s<=''){x=x*+s-'';s=getchar();}
return x*f;
}
int cmp(const node &x,const node &y){
return (x.s==y.s&&x.g<y.g)||x.s<y.s;
}
int Cmp(const edge &x,const edge &y){
return x.g<y.g;
}
int find(int x){
if(x!=fa[x])fa[x]=find(fa[x]);
return fa[x];
}
bool Judge(int x){
cnt=;tot=;falg=;
for(int i=;i<=n;i++)fa[i]=i;
for(int i=;i<=x;i++){
e[++cnt].o=i;e[cnt].g=p[i].g;
e[cnt].u=p[i].u;e[cnt].v=p[i].v;
}
sort(e+,e++cnt,Cmp);
for(int i=;i<=cnt;i++){
int r1=find(e[i].u);
int r2=find(e[i].v);
if(r1!=r2){
tot++;fa[r2]=r1;
}
if(tot==n-){
mg=e[i].g;falg=;break;
}
}
return falg;
}
int main()
{
freopen("road.in","r",stdin);
freopen("road.out","w",stdout);
n=init();m=init();G=init();S=init();
ll u,v,g,s;
for(int i=;i<=m;i++){
u=init();v=init();g=init();s=init();
p[i].u=u;p[i].v=v;p[i].g=g;
p[i].s=s;mig=min(mig,p[i].g);
}
sort(p+,p++m,cmp);
for(int i=;i<=m;i++){
mx=p[i].s*S+mig*G;
if(mx>=ans)break;
if(Judge(i)){
ms=p[i].s;
mx=ms*S+mg*G;
ans=min(ans,mx);
}
}
if(ans==inf*)cout<<"-1"<<endl;
else cout<<ans<<endl;
return ;
}
/*
后来看了题解的方法 在之前暴力的基础上优化一下
每次加入一条边 不用O(m)的跑MST 直接把这条边加到上一次MST的n-1条边里
还有就是每加入一条边 因为之前的n-1条是有序的 直接O(m)插入就好了
这样就成了O(mn) 可能我写的比较挫 先找一遍MST 这个略慢2333 可以卡掉 但是没数据
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define ll long long
#define maxn 410
#define maxm 50010
#define inf 1e18
using namespace std;
int n,m,cnt,tot,fa[maxn],falg;
ll ans=inf*,S,G,ms,mg,mx,mi[maxm];
struct node{
int u,v;ll s,g;
}p[maxm],pp[maxm],e[maxn],ee[maxm];
ll init(){
ll x=;char s=getchar();
while(s<''||s>'')s=getchar();
while(s>=''&&s<=''){x=x*+s-'';s=getchar();}
return x;
}
ll min(ll x,ll y){
return x<y?x:y;
}
int cmp(const node &x,const node &y){
return x.s<y.s;
}
int Cmp(const node &x,const node &y){
return x.g<y.g;
}
int find(int x){
if(x!=fa[x])fa[x]=find(fa[x]);
return fa[x];
}
bool Judge2(int x){
tot=;falg=;int P=cnt+;
e[++cnt]=p[x];cnt=;
for(int i=;i<=n;i++)fa[i]=i;
while(e[P].g<e[P-].g){//插入这排序 快快快
swap(e[P],e[P-]);P--;
}
for(int i=;i<=n;i++){
int r1=find(e[i].u);
int r2=find(e[i].v);
if(r1!=r2){
ee[++cnt]=e[i];
tot++;fa[r2]=r1;
}
if(tot==n-){
mg=e[i].g;falg=;break;
}
}
if(falg)for(int i=;i<=n;i++)e[i]=ee[i];
return falg;
}
bool Judge1(int x){
tot=;falg=;cnt=;int P=x;
for(int i=;i<=n;i++)fa[i]=i;
while(pp[P].g<pp[P-].g){//插入这排序 快快快
swap(pp[P],pp[P-]);P--;
}
for(int i=;i<=x;i++){
int r1=find(pp[i].u);
int r2=find(pp[i].v);
if(r1!=r2){
tot++;fa[r2]=r1;
e[++cnt]=pp[i];
}
if(tot==n-){
mg=pp[i].g;falg=;break;
}
}
return falg;
}
int main()
{
freopen("road.in","r",stdin);
freopen("road.out","w",stdout);
n=init();m=init();G=init();S=init();
int u,v;ll g,s;
for(int i=;i<=m;i++){
u=init();v=init();g=init();s=init();
p[i].u=u;p[i].v=v;p[i].g=g;p[i].s=s;
pp[i].u=u;pp[i].v=v;pp[i].g=g;pp[i].s=s;
}
memset(mi,/,sizeof(mi));
sort(p+,p++m,cmp);sort(pp+,pp++m,cmp);
int start=;
for(int i=;i<=m;i++)
mi[i]=min(mi[i-],p[i].g);
for(int i=;i<=m;i++){
mx=p[i].s*S+mi[i]*G;
if(mx>=ans)break;
if(Judge1(i)){
ms=p[i].s;
mx=ms*S+mg*G;
ans=min(ans,mx);
start=i+;break;
}
}
for(int i=start;i<=m;i++){
mx=p[i].s*S+mi[i]*G;
if(mx>=ans)break;
if(Judge2(i)){
ms=p[i].s;
mx=ms*S+mg*G;
ans=min(ans,mx);
}
}
if(ans==inf*)cout<<"-1"<<endl;
else cout<<ans<<endl;
return ;
}
10.25 noip模拟试题的更多相关文章
- 10.26 noip模拟试题
enc[问题背景]zhx 和他的妹子聊天.[问题描述]考虑一种简单的加密算法.假定所有句子都由小写英文字母构成,对于每一个字母,我们将它唯一地映射到另一个字母.例如考虑映射规则:a->b, b- ...
- 10.3 noip模拟试题
希望[题目描述]网页浏览器者有后退与前进按钮,一种实现这两个功能的方式是用两个栈,“前进栈”.“后退栈”.这里你需要实现以下几个功能:BACK: 如果“后退栈”为空则忽略此命令. 否则将当前两面压入“ ...
- 10.27 noip模拟试题
1.铺瓷砖(tile.cpp/c/pas)[问题描述]有一面很长很长的墙. 你需要在这面墙上贴上两行瓷砖. 你的手头有两种不同尺寸的瓷砖,你希望用这两种瓷砖各贴一行.瓷砖的长可以用分数表示,贴在第一行 ...
- 10.24 noip模拟试题
尼玛pdf依旧不会粘23333 /* 每段合并到总的里面 假设总的有X个 这一段有Y个 一共有X+1个空 那么就有 C(X+1,1)+C(X+1,2)+C(X+1,3)+...+C(X+1,Y) 这样 ...
- 10.18 noip模拟试题
分火腿 (hdogs.pas/.c/.cpp) 时间限制:1s:内存限制 64MB 题目描述: 小月言要过四岁生日了,她的妈妈为她准备了n根火腿,她想将这些火腿均分给m位小朋友,所以她可能需要切火腿. ...
- 10.13 noip模拟试题
Porble 1时间与空间之旅(tstrip.*) 题目描述 公元22××年,宇宙中最普遍的交通工具是spaceship.spaceship的出现使得星系之间的联系变得更为紧密,所以spaceship ...
- 10.11 noip模拟试题
4题均为128M,1s 1. 锻炼计划(exercise.pas) 身体是革命的本钱,OIers不要因为紧张的学习和整天在电脑前而忽视了健康问题.小x设计了自己的锻炼计划,但他不知道这个计划是否可行, ...
- 10.8 noip模拟试题
1.花 (flower.cpp/c/pas) [问题描述] 商店里出售n种不同品种的花.为了装饰桌面,你打算买m支花回家.你觉得放两支一样的花很难看,因此每种品种的花最多买1支.求总共有几种不同的 ...
- 10.4 noip模拟试题
题目名称 PA 青春 三部曲 名称 huakai taritari truetears 输入 huakai.in taritari.in truetears.in 输出 huakai.out tari ...
随机推荐
- bzoj 2002: [Hnoi2010]Bounce 弹飞绵羊 動態樹
2002: [Hnoi2010]Bounce 弹飞绵羊 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 4055 Solved: 2172[Submi ...
- [BZOJ 2594] [Wc2006]水管局长数据加强版 【LCT】
题目链接:BZOJ - 2594 题目分析 这道题如果没有删边的操作,那么就是 NOIP2013 货车运输,求两点之间的一条路径,使得边权最大的边的边权尽量小. 那么,这条路径就是最小生成树上这两点之 ...
- dyld: lazy symbol binding failed: Symbol not found: _objc_setProperty_nonatomic
这个错误,一般在高版本设备里面不会出现,而在低版本会出现比如你的项目或者引入的静态库的Deployment Target设置成了ios6.0而你的测试设备是ios5.0甚至更低,就会出现如上错误.因为 ...
- Spring整合CXF,发布RSETful 风格WebService
原文地址:http://www.cnblogs.com/hoojo/archive/2012/07/23/2605219.html 这篇文章是承接之前CXF整合Spring的这个项目示例的延伸,所以有 ...
- 关于C51内的code,idata,xdata
从数据存储类型来说,8051系列有片内.片外程序存储器,片内.片外数据存储器,片内程序存储器还分直接寻址区和间接寻址类型,分别对应code.data.xdata.idata以及根据51系列特点而设定的 ...
- 转 ---- Asp.net mvc项目分页功能
1.定义一个分页用的Page<T>类 1 /* 使用示例: 2 var pager = new Pager<Article>( 3 this.ControllerContext ...
- Linux下把U盘格式化为fat32
在linux下也是支持fat32的,如果U盘中了病毒可以插入linux系统进行格式化比较安全,下面介绍如何在linux下把u盘格式化为fat32的方法 一.执行fdisk -l查看linux设备,我的 ...
- LINUX系统中动态链接库的创建与使用
大家都知道,在WINDOWS系统中有很多的动态链接库(以.DLL为后缀的文件,DLL即Dynamic Link Library).这种动态链接库,和静态函数库不同,它里面的函数并不是执行程序本身的一部 ...
- 杂项(最小表示法):HZOI 2015 Glass Beads
[题目描述] 给定长度为n(n<=300000)的循环同构的字符串,定义最小表示为该字符串的字典序最小的同构表示,请输出这个表示. [输入格式] 第一行是串的长度,第二行是字符串. [输出格式] ...
- org.springframework.web.context.ContextLoaderListener 转
ContextLoaderListener的作用就是启动Web容器时,自动装配ApplicationContext的配置信息.因为它实现了ServletContextListener这个接口,在web ...