10.12NOIP模拟题(1)
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue> #define N 2001 using namespace std;
int n,m,ans,cnt;
int vis[N],w[N],x[N],deep[N];
int e[N][N];
queue<int>q; inline int read()
{
int x=,f=;char c=getchar();
while(c>''||c<''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x*f;
} void bfs(int now)
{
while(!q.empty()) q.pop();
memset(vis,,sizeof vis);
memset(deep,,sizeof deep);
q.push(now);
while(!q.empty())
{
int u=q.front();q.pop();
ans=max(ans,deep[u]+);
for(int i=;i<=n;i++)
{
if(u==now&&e[i][now])
{
deep[i]=deep[now]+;
q.push(i);
}
else if(deep[i]==deep[u] && e[u][i])
{
deep[i]=deep[u]+;
q.push(i);
}
}
}
} int main()
{
freopen("clique.in","r",stdin);
freopen("clique.out","w",stdout);
int tmp;
n=read();
for(int i=;i<=n;i++) x[i]=read(),w[i]=read();
for(int i=;i<=n;i++) for(int j=;j<=n;j++)
{
if(i==j) continue;
tmp=x[i]-x[j];
if(tmp<) tmp=-tmp;
if(tmp>=w[i]+w[j]) e[i][j]=e[j][i]=;
}
for(int i=;i<=n;i++)
bfs(i);
printf("%d\n",ans);
return ;
}
20暴力23333
/*
将点(xi,wi)看成区间(xi-wi,xi+wi),绝对值去掉移项
那么两个点有连边当且仅当两个区间没有公共点
最多的不重合的区间数就是最大团的点数
删去所有包含其它区间的区间,在剩下的区间中每次贪心取一个能取的坐标最小的区间。
*/
#include<algorithm>
#include<iostream>
#include<cstdio>
using namespace std;
const int maxn=;
int n;
struct zhw{
int l,r;
friend bool operator <(zhw a,zhw b)
{
return a.r<b.r||(a.r==b.r&&a.l>b.l);
}
}a[maxn];
int x,w,l,r;
int main()
{
freopen("clique.in","r",stdin);
freopen("clique.out","w",stdout);
scanf("%d",&n);
for(int i=;i<=n;++i)
{
scanf("%d%d",&x,&w);
a[i].l=x-w,a[i].r=x+w;
}
sort(a+,a+n+);
int pos=a[].r,ans=;
for(int i=;i<=n;++i)
{
if(a[i].l>=pos)ans++,pos=a[i].r;
}
printf("%d",ans);
fclose(stdin);fclose(stdout);
return ;
}
/*
可以对硬币的编号取模k,这样就分成了k组
每一组中,若有偶数堆硬币那这一组硬币可以全部拿走。
若有奇数堆硬币那一定会有一堆剩余
而且剩余的一定是编号为奇数的那一堆(自己写一下就能发现一定是编号为奇数的剩余)
同样把这一组的所有硬币价值加起来,再减去这一堆中编号为奇数,并且价值最小的那一堆即可。
*/
#include <cstdio>
#include <iostream> #define ll long long using namespace std;
int n,k;
ll a[]; int main()
{
freopen("coin.in","r",stdin);
freopen("coin.out","w",stdout); scanf("%d%d",&n,&k);k--;
for (int i=;i<n;i++) scanf("%lld",&a[i]); ll ret=;
for (int i=;i<=k;i++)
{
ll mini=1e9,tot=;
for (int j=i;j<n;j+=k+)
{
tot^=;
if (tot) mini=min(mini,a[j]);
ret+=a[j];
}
ret-=tot*mini;
}
cout<<ret;
}
/*
水水的dp
*/
#include<iostream>
#include<cstring>
#include<cstdio> #define N 1007 using namespace std;
int n,t;
int v[N],sum[N];
int f[N]; int main()
{
freopen("cherry.in","r",stdin);
freopen("cherry.out","w",stdout);
scanf("%d%d",&n,&t);
for(int i=;i<=n;++i)
scanf("%d",&v[i]),sum[i]=sum[i-]+v[i];
memset(f,/,sizeof(f));
f[]=;
for(int i=;i<=n;++i)
for(int j=;j<=i;j++)
f[i]=min(f[i],f[j-]+(sum[i]-sum[j-]-t)*(sum[i]-sum[j-]-t));
printf("%d",f[n]);
return ;
}
10.12NOIP模拟题(1)的更多相关文章
- 10.12NOIP模拟题(2)
/* 有谁知道这道题结论是怎么来的? 晚上问问学数学的孩子23333 */ #include<iostream> #include<cstdio> #include<cs ...
- 9.12NOIP模拟题
NOIP 2017 全假模拟冲刺 hkd 题目名称 Spfa 走楼梯缩小版 滑稽 题目类型 传统 传统 传统 ...
- 10.13NOIP模拟题
/* 容斥原理 考虑到a[i]要么不会太大,要么就对答案贡献很小 dfs即可 */ #include<bits/stdc++.h> #define ll long long #define ...
- 10.23NOIP模拟题
叉叉题目描述现在有一个字符串,每个字母出现的次数均为偶数.接下来我们把第一次出现的字母 a 和第二次出现的 a 连一条线,第三次出现的和四次出现的字母 a 连一条线,第五次出现的和六次出现的字母 a ...
- 10.9NOIP模拟题
/* big模拟 细节不少 remove表示这个玩意儿在这一秒有没有移动 注意在一秒内所有小葱一起移动,所以如果一个一个处理 别忘了“错位”这种情况 */ #include<iostream&g ...
- 10.11NOIP模拟题(3)
/* 可以看出,对于一段区间[L,R]如果统计了答案 若a[L]<a[R],那么当右端点往左移时答案不会更优,a[R]>a[L]同理 所以两个指针分别从头尾往中间扫那边小移哪边即可. */ ...
- 10.11NOIP模拟题(2)
/* string水过 */ #include<bits/stdc++.h> #define N 1001 using namespace std; int n,x,y,m,pre; st ...
- poj 1008:Maya Calendar(模拟题,玛雅日历转换)
Maya Calendar Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 64795 Accepted: 19978 D ...
- poj 1888 Crossword Answers 模拟题
Crossword Answers Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 869 Accepted: 405 D ...
随机推荐
- myeclipse通过数据表生成jpa或hibernate实体---https://blog.csdn.net/partner4java/article/details/8560289
myeclipse通过数据表生成jpa或hibernate实体-----https://blog.csdn.net/partner4java/article/details/8560289
- JavaEE JDBC 事务
JDBC 事务 @author ixenos 事务 1.概念:我们将一组语句构建成一个事务(trans action),当所有语句顺利执行之后,事务可以被提交(commit):否则,如果其中某个语句遇 ...
- NYOJ-851寻找最大数(二),栈贪心!
寻找最大数(二) 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描述 给你一个数字n(可能有前缀0). 要求从高位到低位,进行 进栈出栈 操作,是最后输出的结果最大. 输入 ...
- 1004. 成绩排名 (20) (快速排序qsort函数的使用问题)
读入n名学生的姓名.学号.成绩,分别输出成绩最高和成绩最低学生的姓名和学号. 输入格式:每个测试输入包含1个测试用例,格式为 第1行:正整数n 第2行:第1个学生的姓名 学号 成绩 第3行:第2个学生 ...
- POJ 1679 判最小生成树的不唯一性 或 利用次小生成树求解
题目大意: 给定一个无向图,寻找它的最小生成树,如果仅有一种最小生成树,输出所有边的和,否则输出unique! 根据kruscal原理来说,每次不断取尽可能小的边不断添加入最小生成树中,那么可知如果所 ...
- struct init
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <stdbool.h& ...
- UVA 11400_ Lighting System Design
题意: 给定一系列灯泡的额定功率,电源价钱,一个灯泡的价格以及系统所需该种灯泡的数量.已知流过灯泡的电流相等,所以为省钱可以将电压小的灯泡换成电压大的灯泡,但是不能换成电压更小的灯泡,问最少要花多少钱 ...
- Java电商项目-6.实现门户首页数据展示_Redis数据缓存
目录 项目的Github地址 需求介绍 搭建Redis集群环境 下面先描述单机版redis的安装 下面将进行Redis3主3从集群环境搭建 基于SOA架构, 创建门户ashop-portal-web门 ...
- Redis持久化方式--RDB和AOF
转载于:https://www.cnblogs.com/xingzc/p/5988080.html Redis提供了RDB持久化和AOF持久化 RDB机制的优势和略施 RDB持久化是指在指定的时间间隔 ...
- NOIP 2010 机器翻译
P1540 机器翻译 题目背景 小晨的电脑上安装了一个机器翻译软件,他经常用这个软件来翻译英语文章. 题目描述 这个翻译软件的原理很简单,它只是从头到尾,依次将每个英文单词用对应的中文含义来替换.对于 ...