题还没补完

以下是牢骚:删了

现在只有六个。。。太恐怖了,我发现四星场我连300人的题都不会啊。

C:最短路加一维状态就好了叭。。嗯,一开始没看到输出的那句话 那个  "."也要输出,然后n,m看反了,这反人类啊这nm。

#include <bits/stdc++.h>
#define mk(a,b) make_pair(a,b)
#define pii pair<int,int>
using namespace std;
typedef long long ll;
struct node{
int u,t,p;
bool operator<(const node&rhs)const {
return p>rhs.p;
}
};
int x,n,m,l;
vector<int>g[];
int t[],p[],dis[][];
void Dijkstra(){
for(int i=;i<=n;i++)for(int j=;j<=x;j++)dis[i][j]=;
if(t[]>x)return;
dis[][t[]]=p[];
priority_queue<node>Q;
Q.push(node{,t[],p[]});
while (!Q.empty()){
node fr = Q.top();Q.pop();
if(dis[fr.u][fr.t]<fr.p)continue;
if(fr.t+t[fr.u]<=x&&fr.p+p[fr.u]<dis[fr.u][fr.t+t[fr.u]]){
dis[fr.u][fr.t+t[fr.u]]=fr.p+p[fr.u];
Q.push(node{fr.u,fr.t+t[fr.u],fr.p+p[fr.u]});
}
for(auto u:g[fr.u]){
if(fr.t+t[u]+l<=x&&fr.p+p[u]<dis[u][fr.t+t[u]+l]) {
dis[u][fr.t+t[u]+l]=fr.p+p[u];
Q.push(node{u, fr.t + t[u] + l, fr.p + p[u]});
}
}
}
}
int main(){
ios::sync_with_stdio(false);
cin>>x>>n>>m>>l;
int a,b;
for(int i=;i<=m;i++){
cin>>a>>b;
g[a].push_back(b);
g[b].push_back(a);
}
for(int i=;i<=n;i++){
cin>>t[i]>>p[i];
}
Dijkstra();
if(dis[][x]==)cout<<"It is a trap."<<endl;
else cout<<dis[][x]<<endl;
}

D:签到,我写的很傻逼

 #include <bits/stdc++.h>
#define mk(a,b) make_pair(a,b)
#define pii pair<int,int>
using namespace std;
typedef long long ll;
string s1,s2,s;
int n,m,cnt=,vis[];
map<string,int>mp;
vector<int>g[];
set<int> st[];
void dfs(int v){
st[v].insert(v);
for(auto u:g[v]){
dfs(u);
for(auto tmp:st[u])
st[v].insert(tmp);
}
}
int main(){
ios::sync_with_stdio(false);
cin>>n>>m;
while (n--){
cin>>s1>>s>>s>>s>>s2;
if(!mp.count(s1))mp[s1]=cnt++;
if(!mp.count(s2))mp[s2]=cnt++;
g[mp[s2]].push_back(mp[s1]);
}
for(int i=;i<cnt;i++){
if(!vis[i])
dfs(i);
}
while (m--){
cin>>s1>>s>>s>>s>>s2;
if(!mp.count(s1)||!mp.count(s2)){
cout<<"Pants on Fire"<<endl;
} else{
if(st[mp[s2]].count(mp[s1])){
cout<<"Fact"<<endl;
} else if(st[mp[s1]].count(mp[s2])){
cout<<"Alternative Fact"<<endl;
} else{
cout<<"Pants on Fire"<<endl;
}
}
}
}

G:现学的那个什么皮克公式。好神奇啊!虽然不知道为什么。然后仔细读题会发现他给你的点是按顺序的。算一下叉积就完了。可以百度 皮克公式呀qwq

 #include <bits/stdc++.h>
#define mk(a,b) make_pair(a,b)
#define pii pair<int,int>
using namespace std;
typedef long long ll;
int n;
struct point{
ll x,y;
}p[];
ll cross(point k1,point k2){return k1.x*k2.y-k1.y*k2.x;}
ll gcd(ll a,ll b){
a=abs(a);b=abs(b);
if(a==)return b;
if(b==)return a;
return __gcd(a,b);
}
int main(){
//ios::sync_with_stdio(false);
scanf("%d",&n);
for(int i=;i<n;i++)
scanf("%lld%lld",&p[i].x,&p[i].y);
ll S=,cnt=;
for(int i=;i<n;i++){
S+=cross(p[i],p[(i+)%n]);
}
S/=;
S=abs(S);
for(int i=;i<n;i++){
cnt+=gcd(p[i].x-p[(i+)%n].x,p[i].y-p[(i+)%n].y);
}
ll a = S-cnt/+;
printf("%lld\n",a);
}
/**
4
0 0
0 10
10 10
10 0 4
0 3
3 0
0 -1
-1 0
*/

F:哇上来我一看,这直接枚举不就完了吗!TLE ON TEST 8。说好的玄学复杂度呢呜呜呜  自闭。 后来想到会有大量重复的过程,,但是我学艺不精,写的最大流,就不会改了。。昨天看了题解!

哇!二分图匹配,然后每个点再做两次增广!用另外一个数组把一开始的存下来。草!这题竟该死的巧妙。匈牙利大法好哇。

 #include <bits/stdc++.h>
using namespace std;
const int N = 1e5+;
const int INF = 0x3f;
struct Edge{
int u,v,nxt;
Edge(int u=,int v=,int nxt=):u(u),v(v),nxt(nxt){}
}edge[*N];
int n,m,k,cnt;
int head[N],d[N],c[N];
void addEdge(int u,int v){
edge[++cnt]=Edge(u,v,head[u]);
head[u]=cnt;
}
int match[N],vis[N],tmp[N];
bool dfs(int u){
for(int i=head[u];~i;i=edge[i].nxt){
int v = edge[i].v;
if(vis[v])continue;
vis[v]=;
if(match[v]==-||dfs(match[v])){
match[v]=u;
return true;
}
}
return false;
}
void init(){
memset(head,-, sizeof(head));
cnt=;
}
int main(){
ios::sync_with_stdio(false);
init();
scanf("%d%d%d",&n,&m,&k);
int u,v;
for(int i=;i<=k;i++){
scanf("%d%d",&u,&v);
addEdge(u,v);
}
int mx=;
memset(match,-, sizeof(match));
for(int i=;i<=n;i++){
memset(vis,, sizeof(vis));
if(dfs(i))mx++;
}
memcpy(tmp,match,sizeof(match));
int ans =;
for(int i=;i<=n;i++){
int num=;
while (dfs(i)&&num<){
memset(vis,, sizeof(vis));
num++;
}
ans=max(ans,num);
memcpy(match,tmp, sizeof(tmp));
}
printf("%d\n",ans+mx);
}

I:签到

 #include <bits/stdc++.h>
#define mk(a,b) make_pair(a,b)
#define pii pair<int,int>
using namespace std;
typedef long long ll;
const int N = 3e5+;
int n,m;
int a[N],dp[N][];
int main(){
ios::sync_with_stdio(false);
cin>>n>>m;
for(int i=;i<=n;i++)cin>>a[i];
for(int i=m+;i<=n;i++){
dp[i][]=max(dp[i-m][],dp[i-m][])+a[i];
dp[i][]=max(dp[i-][],dp[i-][]);
}
cout<<max(dp[n][],dp[n][]);
}

K:签到

 #include <bits/stdc++.h>
#define mk(a,b) make_pair(a,b)
#define pii pair<int,int>
using namespace std;
typedef long long ll;
int n,d,k;
struct Node{
string s;
int c;
bool operator < (const Node& a)const {
return c<a.c;
}
};
priority_queue<Node> q;
vector<string>ans;
int main(){
ios::sync_with_stdio(false);
cin>>n>>d>>k;
string s;int c;
while (n--){
cin>>s>>c;
q.push(Node{s,c});
}
int sum=;
while (!q.empty()&&sum<d){
sum+=q.top().c;
ans.push_back(q.top().s);
q.pop();
}
if(ans.size()>k||sum<d){
cout<<"impossible"<<endl;
} else{
cout<<ans.size()<<endl;
for(auto s:ans){
cout<<s<< ", YOU ARE FIRED!"<<endl;
}
}
}

gym 101873的更多相关文章

  1. gym/101873/GCPC2017

    题目链接:https://codeforces.com/gym/101873 C. Joyride 记忆化搜索形式的dp #include <algorithm> #include < ...

  2. Gym 101873F Plug It In(二分图匹配)

    题目链接:http://codeforces.com/gym/101873/problem/F 题意:有n个插孔,m个机器,和一个插板,一个插孔可以连接一个机器,插板可以使一个插孔连接三个机器,找到最 ...

  3. Gym 101873C - Joyride - [最短路变形][优先队列优化Dijkstra]

    题目链接:http://codeforces.com/gym/101873/problem/C 题意: 这是七月的又一个阳光灿烂的日子,你决定和你的小女儿一起度过快乐的一天.因为她真的很喜欢隔壁镇上的 ...

  4. Gym 101873D - Pants On Fire - [warshall算法求传递闭包]

    题目链接:http://codeforces.com/gym/101873/problem/D 题意: 给出 $n$ 个事实,表述为 "XXX are worse than YYY" ...

  5. Gym 101873G - Water Testing - [皮克定理]

    题目链接:http://codeforces.com/gym/101873/problem/G 题意: 在点阵上,给出 $N$ 个点的坐标(全部都是在格点上),将它们按顺序连接可以构成一个多边形,求该 ...

  6. Gym 101873I - Uberwatch - [DP]

    题目链接:http://codeforces.com/gym/101873/problem/I 题意: 给出 $n(1 \le n \le 300000)$ 个单位时间,每个单位时间给出一个 $x_i ...

  7. Gym 101873K - You Are Fired - [贪心水题]

    题目链接:http://codeforces.com/gym/101873/problem/K 题意: 现在给出 $n(1 \le n \le 1e4)$ 个员工,最多可以裁员 $k$ 人,名字为 $ ...

  8. codeforces gym #101873B. Buildings(Polya定理)

    参考博客: https://blog.csdn.net/liangzhaoyang1/article/details/72639208 题目链接: https://codeforces.com/gym ...

  9. Joyride (spaf)

    题目链接:https://codeforces.com/gym/101873/problem/C spaf的复杂度有点迷,按道理来说,一个简单的spaf在这题的复杂度是1e9,所以不敢写,然后用优先队 ...

随机推荐

  1. 通过脚本调用MSBuild编译项目时指定Configuration(解決方案配置)和Platform(解決方案平台),Rebuid(重新生成解决方案),Clean(清理解决方案)

    为了方便打包测试,自己PowerShell写了一个编译和发布的脚本,调用msbuild通过命令行来编译当前解决方案 后来发现一个问题,用VS编译解决方案,我通过 项目属性-Build设置 Releas ...

  2. Gcode命令【转】

    https://www.jianshu.com/p/f8a328457a45 简述 研究过3D打印机的朋友,都会用到G-code文件.要使用3D打印机打印东西要经过几个步骤:        1.创建3 ...

  3. Jetpack 架构组件 Paging 分页加载 MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...

  4. zigw 和 nanoWatch, libudev.so 和 XMR 挖矿程序查杀记录

    最近这两天以来,服务器一致声音很响.本来以为有同事在运行大的程序,结果后来发现持续很长时间都是这样,并没有停的样子.后来查了一下,发现有几个可疑进程导致,干掉之后,果然服务器静悄悄了. 但是,问题并没 ...

  5. linux 设备驱动概述

    linux 设备驱动概述 目前,Linux软件工程师大致可分为两个层次: (1)Linux应用软件工程师(Application Software Engineer):       主要利用C库函数和 ...

  6. Effective Java 第三版——64. 通过对象的接口引用对象

    Tips 书中的源代码地址:https://github.com/jbloch/effective-java-3e-source-code 注意,书中的有些代码里方法是基于Java 9 API中的,所 ...

  7. SNF软件开发机器人-子系统-功能-功能类型(普通表改为树型表)

    功能类型(普通表改为树型表) 功能类型分为普通功能和树形功能.因为资源表中不存在ParentId字段,故只能将多表的主表改为树型表. 1.效果展示: 2.使用说明: (1)当需要用一张普通的资源表显示 ...

  8. CentOS 7下升级Python版本到3.x系列

    由于python官方已宣布2.x系列即将停止支持,为了向前看,我们升级系统的python版本为3.x系列服务器系统为当前最新的CentOS 7.4 1.安装前查看当前系统下的python版本号 # p ...

  9. Android recovery支持adb shell

    Android recovery支持adb shell 近期开发过程注意到recovery不支持adb shell.为了便于调试方便,决定添加此功能. 刚開始我们採用的是user版本号系统,进入rec ...

  10. firewall防火墙使用

    firewall用zone来区分管理,默认有以下一些zone: 丢弃(DROP) 任何流入网络的包都被丢弃,不作出任何响应.只允许流出的网络连接. 阻塞(Block) 任何进入的网络连接都被拒绝,并返 ...