噩梦的回忆。。

上周日在机房打的模拟赛,结果十分惨烈,就最后一题yy出了正解结果玄学的只拿了80

考试结果:0+0+80=80

订正时对着T3打了2hours结果还是90

订正结果:100+100+90=290

我太弱了QAQ

T1 Luogu P5196 [USACO19JAN]Cow Poetry

题目链接

思路:dp+神奇的数学推导

快速幂一开始还写锅了,受到了ftq大佬的嘲笑

code

#include<bits/stdc++.h>
using namespace std;
const int MOD=1e9+7,MAXN=5000+10;
int f[5010][MAXN],s[MAXN],c[MAXN],g[MAXN],num[35],n,m,k;
long long ans,re=1;
long long pow(int b, int p) {
if (p == 0) {
return 1;
}
long long x = b;
long long ans = 1;
while (p > 0) {
if (p % 2 == 1) {
ans = ans * x % MOD;
}
x = x * x % MOD;
p = p >> 1;
}
return ans % MOD;
}
void debug()
{
for(int i=1;i<=5;++i){
cout<<f[k][i]<<" ";
}
cout<<endl;
for(int i=0;i<=5;++i){
cout<<num[i]<<" ";
}
cout<<endl;
}
signed main()
{
// freopen(".in","r",stdin);
// freopen(".out","w",stdout);
cin>>n>>m>>k;
for(int i=1;i<=n;++i){
cin>>s[i]>>c[i];
}
g[0]=1;
for(int i=1;i<=k;i++){
for(int j=1;j<=n;j++){
if(i-s[j]>=0){
(f[i][c[j]]+=g[i-s[j]])%=MOD;
(g[i]+=g[i-s[j]])%=MOD;
}
}
}
for(int i=1;i<=m;++i){
char ch;
cin>>ch;
num[ch-'A']++;
}
// debug();
for(int i=0;i<26;++i){
if(num[i]){
ans=0;
for(int j=1;j<=n;++j){
if(f[k][j]){
(ans+=pow(f[k][j],num[i]))%=MOD;
// cout<<ans<<endl; }
}
(re*=ans)%=MOD;
}
}
cout<<re<<endl;
return 0;
}

T2 Luogu P5200 [USACO19JAN]Sleepy Cow Sorting

题目链接

思路:神奇的推导+树状数组

code

#include<bits/stdc++.h>
using namespace std;
const int MAXN=1e5+10;
inline int lowbit(int x){return x&(-x);}
int ans[MAXN],num[MAXN],tree[MAXN],n,sum,k;
void add(int x)
{
for(int i=x;i<=n;i+=lowbit(i)){
tree[i]++;
}
}
int query(int x)
{
int re=0;
for(int i=x;i;i-=lowbit(i)){
re+=tree[i];
}
return re;
}
int main()
{
// freopen(".in","r",stdin);
// freopen(".out","w",stdout);
cin>>n;
for(int i=1;i<=n;++i){
cin>>num[i];
}
sum=n,k=0;
while(num[n-k]>num[n-k-1]){
add(num[n-k]);
sum--,k++;
}
add(num[n-k]);
sum--;
for(int i=1;i<=sum;++i){
add(num[i]);
ans[i]=sum-i+query(num[i]-1);
}
cout<<sum<<endl;
for(int i=1;i<=sum;++i){
cout<<ans[i]<<" ";
}
return 0;
}

T3 Luogu P5201 [USACO19JAN]Shortcut

思路:dij+最短路树

code

#include<bits/stdc++.h>
#define int long long
#define ll long long
using namespace std;
const int MAXN=1e5+10,INF=0x3f3f3f3f;
inline int read()
{
int s=0,f=1;
char ch=getchar();
while(ch<'0'||ch>'9'){
if(ch=='-')
f=-1;
ch=getchar();
}
while(ch>='0'&&ch<='9'){
s=s*10+ch-'0';
ch=getchar();
}
return s*f;
} struct NODE {
int first,second;
bool operator<(NODE b) const { return (b.first==first)?b.second<second:b.first < first; }
};
int cnt,Cnt,m,n,T;
int head[MAXN],Head[MAXN],from[MAXN],siz[MAXN],v[MAXN];
ll dist[MAXN],ans=0;
priority_queue <NODE > q;
bool vis[MAXN],vi[MAXN]; void debug()
{
puts("head Head from siz dist");
for(int i=1;i<=n;++i){
cout<<head[i]<<" "<<Head[i]<<" "<<from[i]<<" "<<siz[i]<<" "<<dist[i]<<endl;
}
} struct node{
int to,next,l;
}edge[MAXN];
void addedge(int x,int y,int l)
{
edge[++cnt].to=y;
edge[cnt].l=l;
edge[cnt].next=head[x];
head[x]=cnt;
} struct Node{
int to,next;
}Edge[MAXN];
void Addedge(int x,int y)
{
Edge[++Cnt].to=y;
Edge[Cnt].next=Head[x];
Head[x]=Cnt;
} void dij()
{
memset(dist,INF,sizeof(dist));
dist[1]=0;
NODE a;
a.first=0,a.second=1;
q.push(a);
while(!q.empty()){
NODE now=q.top();q.pop();
int x=now.second;
// if(vi[x])continue;
// vi[x]=1;
// cout<<x<<"while\n";
for(int i=head[x];i;i=edge[i].next){
// cout<<i<<"i\n";
int y=edge[i].to;
// cout<<y<<" y\n";
if(dist[x]+edge[i].l<dist[y]){
// cout<<y<<"y\n";
NODE aa;
aa.second=y,aa.first=dist[y];
dist[y]=dist[x]+edge[i].l;
from[y]=x;
// cout<<"to"<<y<<endl;
q.push(aa);
}
}
}
} void build()
{
for(int i=1;i<=n;++i){
Addedge(i,from[i]);
Addedge(from[i],i);
}
} int dfs(int x,int fa)
{
vis[x]=1;
siz[x]+=v[x];
for(int i=Head[x];i;i=Edge[i].next){
int y=Edge[i].to;
if(!vis[y]&&y!=fa){
siz[x]+=dfs(y,x);
}
}
return siz[x];
} signed main()
{
// freopen("test08.in","r",stdin);
// freopen("1.out","w",stdout);
cin>>n>>m>>T;
for(int i=1;i<=n;++i){
v[i]=read();
}
for(int i=1;i<=m;++i){
int x=read(),y=read(),t=read();
addedge(x,y,t);
addedge(y,x,t);
}
dij();
build();
dfs(1,0);
// debug();
for(int i=1;i<=n;++i){
ans=max(ans,siz[i]*(dist[i]-T));
}
cout<<ans<<endl;
return 0;
}

USACO19JAN Gold题解的更多相关文章

  1. [USACO19JAN]Shortcut题解

    本题算法:最短路树 这是个啥玩意呢,就是对于一个图,构造一棵树,使从源点开始的单源最短路径与原图一模一样.怎么做呢,跑一边Dijkstra,然后对于一个点u,枚举它的边,设当前的边为cur_edge, ...

  2. 1702: [Usaco2007 Mar]Gold Balanced Lineup 平衡的队列

    1702: [Usaco2007 Mar]Gold Balanced Lineup 平衡的队列 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 510  S ...

  3. Gold Balanced Lineup POJ - 3274

    Description Farmer John's N cows (1 ≤ N ≤ 100,000) share many similarities. In fact, FJ has been abl ...

  4. codevs 2602 最短路径问题——良心题解

    2602 最短路径问题 时间限制: 1 s 空间限制: 32000 KB 题目等级 : 黄金 Gold 题解 题目描述 Description 平面上有n个点(n<=100),每个点的坐标均在- ...

  5. LeetCode 1219. Path with Maximum Gold

    原题链接在这里:https://leetcode.com/problems/path-with-maximum-gold/ 题目: In a gold mine grid of size m * n, ...

  6. AC日记——楼房 codevs 2995

    2995 楼房  时间限制: 1 s  空间限制: 256000 KB  题目等级 : 黄金 Gold 题解  查看运行结果     题目描述 Description 地平线(x轴)上有n个矩(lou ...

  7. AC日记——砍树 codevs 1388

    1388 砍树  时间限制: 1 s  空间限制: 256000 KB  题目等级 : 黄金 Gold 题解  查看运行结果     题目描述 Description 伐木工人米尔科需要砍倒M米长的木 ...

  8. AC日记——蓬莱山辉夜 codevs 2830

    2830 蓬莱山辉夜  时间限制: 1 s  空间限制: 32000 KB  题目等级 : 黄金 Gold 题解  查看运行结果     题目描述 Description 在幻想乡中,蓬莱山辉夜是月球 ...

  9. AC日记——二叉堆练习3 codevs 3110

    3110 二叉堆练习3  时间限制: 3 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解       题目描述 Description 给定N(N≤500,000)和N个整 ...

随机推荐

  1. rsync的简介及使用

    1.rsync的基础概述 1.什么是备份 相当于给源文件增加一个副本,但是备份只会备份当前状态的数据,当你在写数据是,不会备份新写入的数据,除非自己手动在备份一次. 2.为什么要做备份 1.需要备份一 ...

  2. 新终端必须source /etc/profile的解决办法,同时解决变色问题

    Linux环境变量文件 /etc/profile:在登录时,操作系 统定制用户环境时使用的第一个文件 ,此文件为系统的每个用户设置环境信息,当用户第一次登录时,该文件被执行. /etc /enviro ...

  3. CSP2019 树上的数 题解

    题面 这是一道典型的部分分启发正解的题. 所以我们先来看两个部分分. Part 1 菊花图 这应该是除了暴力以外最好想的一档部分分了. 如上图(节点上的数字已省略),如果我们依次删去边(2)(1)(3 ...

  4. mathematica练习程序(曲线的曲率与挠率)

    曲线的曲率k表示曲线的弯曲程度. 计算公式: 曲线的挠率tao表示曲率平面的扭曲程度,平面曲线挠率为0. 计算公式: 这里r代表曲线方程,比如有如下曲线方程:r={a*cos(t),a*sin(t), ...

  5. 跳出"低水平勤奋陷阱"

    "低水平勤奋陷阱":摘记更多的知识 读书是获得知识的最基本,最重要的方式,但读书需要方法 所谓"低水平勤奋陷阱",就是花费了大量的时间和精力,但得到的结果却微乎 ...

  6. Flink1.7.2安装部署的几种方式

    原文链接:https://blog.csdn.net/a_drjiaoda/article/details/88037282 前言:Flink的运行一般分为三种模式,即local.Standalone ...

  7. 一次业务网关用ASP.NET Core 2.1重构的小结

    目录 前言 统一鉴权 服务限流 路由转发 参数重组 链路跟踪 熔断降级 服务计次 业务指标监控 日志记录 迭代更新 总结 前言 对于API网关,业界貌似对它进行下划分,有下面几个分类/场景. 面向We ...

  8. KeContextToKframes函数逆向

    在逆向_KiRaiseException(之后紧接着就是派发KiDispatchException)函数时,遇到一个 KeContextToKframes 函数,表面意思将CONTEXT转换为 TRA ...

  9. Solr java.sql.SQLException: null, message from server: "Host 'xxx' is not allowed to connect to this MySQL server

    在用solr从mysql导入数据的时候,因为linux和本机的数据库不在同一个ip段上, 又因为本地的mysql没有设置远程其它ip可以访问所以就报了如下错误 解决办法: 在mysql任意可以输入查询 ...

  10. Spring Boot快速集成kaptcha生成验证码

    Kaptcha是一个非常实用的验证码生成工具,可以通过配置生成多样化的验证码,以图片的形式显示,从而无法进行复制粘贴:下面将详细介绍下Spring Boot快速集成kaptcha生成验证码的过程. 本 ...