AtCoder Beginner Contest 274「A」「B」「C dfs」「D 暴力dp?」「E 旅行商状压dp」「F 排序」
admin
2024-01-17 14:54:24
0

AtCoder Beginner Contest 274

A - Batting Average

题目描述:

输出 ba\frac{b}{a}ab​,保留3位小数

#include 
using namespace std;#define endl '\n'
#define inf 0x3f3f3f3f
#define mod7 1000000007
#define mod9 998244353
#define m_p(a,b) make_pair(a, b)
#define mem(a,b) memset((a),(b),sizeof(a))
#define io ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
typedef long long ll;
typedef pair  pii;#define MAX 300000 + 50
int n, m, k, x;
int tr[MAX];void work(){double a, b;cin >> a >> b;printf("%.3f\n",b/a);
}int main(){io;work();return 0;
}

B - Line Sensor

题目描述:

输入一个n*m的字符串矩型,输出每一列的#的数量

#include 
using namespace std;#define endl '\n'
#define inf 0x3f3f3f3f
#define mod7 1000000007
#define mod9 998244353
#define m_p(a,b) make_pair(a, b)
#define mem(a,b) memset((a),(b),sizeof(a))
#define io ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
typedef long long ll;
typedef pair  pii;#define MAX 300000 + 50
int n, m, k, x;
char p;
int num[MAX];void work(){cin >> n >> m;for(int i = 1; i <= n; ++i){for(int j = 1; j <= m; ++j){cin >> p;num[j] += (p == '#');}}for(int i = 1; i <= m; ++i)cout << num[i] << ' ';}int main(){io;work();return 0;
}

C - Ameba

题目描述:

给定一个长度为n的序列,现在有一个空树,只有一个根结点1a[i]表示在第i秒产生两个最新的子节点,编号取未出现的最新的俩,输出1-2*n-1的每个点到根节点的距离

思路:

建好图以后dfs一次就行

#include 
using namespace std;#define endl '\n'
#define inf 0x3f3f3f3f
#define mod7 1000000007
#define mod9 998244353
#define m_p(a,b) make_pair(a, b)
#define mem(a,b) memset((a),(b),sizeof(a))
#define io ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
typedef long long ll;
typedef pair  pii;#define MAX 500000 + 50
int n, m, k, x;
char p;
int num[MAX];
vectorG[MAX];void dfs(int u, int fa){num[u] = num[fa] + 1;for(auto v : G[u]){if(v == fa)continue;dfs(v, u);}
}void work(){cin >> n;int tot = 1;for(int i = 1; i <= n; ++i){cin >> x;++tot;G[x].push_back(tot);G[tot].push_back(x);++tot;G[x].push_back(tot);G[tot].push_back(x);}dfs(1, 0);for(int i = 1; i <= tot; ++i)cout << num[i] - 1<< endl;
}int main(){io;work();return 0;
}

D - Robot Arms 2

题目描述:

在一个二维平面,起点是(0,0),给你n个数字,表示每次移动的距离,且第一次必须是往右移动,将所有相邻的点连起来,要保证相邻的线之间的夹角是90度,问是否存在一条路径能到达(x,y)

思路:

由于要保证相邻的线之间的夹角是90度,也就说明了i是奇数的时候只能左右走,i是偶数的时候只能上下走,我们就可以分开考虑

现在就可以把题目转换成:

在一个数轴上,你最开始位于ar[1]的位置,可以进行m次移动,每次移动只能往左或者往右移动,问能不能到达x

数据范围不大,我们开一个map暴力更新就行

#include 
using namespace std;#define endl '\n'
#define inf 0x3f3f3f3f
#define mod7 1000000007
#define mod9 998244353
#define m_p(a,b) make_pair(a, b)
#define mem(a,b) memset((a),(b),sizeof(a))
#define io ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
typedef long long ll;
typedef pair  pii;#define MAX 300000 + 50
int n, m, k, x, y;
int tr[MAX];void work(){cin >> n >> x >> y;for(int i = 1; i <= n; ++i){cin >> tr[i];}vectorar, br;for(int i = 2; i <= n; i += 2)ar.push_back(tr[i]);for(int i = 3; i <= n; i += 2)br.push_back(tr[i]);mapmp1;mp1[0] = 1;for(auto x : ar){mapmp;for(int j = -10000; j <= 10000; ++j){if(mp1.count(j)){mp[j-x] = 1;mp[j+x] = 1;}}mp1 = mp;for(auto [x,y] : mp)mp1[x] = 1;}mapmp2;mp2[tr[1]] = 1;for(auto x : br){mapmp;for(int j = -10000; j <= 10000; ++j){if(mp2.count(j)){mp[j-x] = 1;mp[j+x] = 1;}}mp2 = mp;}if(mp1[y] && mp2[x])cout << "Yes\n";else cout << "No\n";
}int main(){io;work();return 0;
}

E - Booster

题目描述:

二维平面,给出n个城镇的坐标,和m个宝箱的坐标,每拿到一个宝箱,就会使得自己的移动速度翻倍,你从(0,0),必须要经过n个城镇,宝箱不做要求,问回到(0,0)的最短时间是多少,初始速度是1

思路:

壮压dp

dp[i][j]表示状态为i,且当前在j的最短时间,

i是长度为n+m的二进制数,每个是1的位置的点表示已经去过了,前m个是包箱,后n个是城镇

然后就是简单的转移

#include 
using namespace std;#define endl '\n'
#define inf 0x3f3f3f3f
#define mod7 1000000007
#define mod9 998244353
#define m_p(a,b) make_pair(a, b)
#define mem(a,b) memset((a),(b),sizeof(a))
#define io ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
typedef long long ll;
typedef pair  pii;#define MAX 300000 + 50
int a, b;
int n;
pii tr[100];
double dp[MAX][20];double cal(int i, int j){return sqrt((tr[i].first - tr[j].first)*(tr[i].first - tr[j].first)+(tr[i].second - tr[j].second)*(tr[i].second - tr[j].second));
}bool judge(int p){if((p & ((1<cin >> a >> b;n = a + b;tr[0] = m_p(0, 0);for(int i = 1; i <= n; ++i){cin >> tr[i].first >> tr[i].second;}for(int i = 0; i < (1<dp[1<<(i-1)][i] = cal(0, i);}for(int i = 0; i < (1<bitset<10>b(i>>a);double v = pow(2, b.count());for(int j = 1; j <= n; ++j){if(!(1 & (i>>(j-1))))continue;for(int k = 1; k <= n; ++k){if(1 & (i>>(k-1)))continue;double p = cal(j, k) / v;dp[i|(1<<(k-1))][k] = min(dp[i|(1<<(k-1))][k], dp[i][j] + p);}}}double ans = 1e14;for(int i = 0; i < (1<if(!judge(i))continue;bitset<10>b(i>>a);double v = pow(2, b.count());for(int j = 1; j <= n; ++j){if(!(i & ((1<io;work();return 0;
}

F - Fishing

题目描述:

一维直线上有n条鱼,每条鱼的重量是ai,初始位置是xi,速度是vi

你有一个长度为k的鱼网,你可以在任意时间下网一次,问最多能抓到的鱼的重量是多大

思路:

我们枚举每条鱼作为鱼网起点,其他每条鱼最多进一次鱼网,出一次鱼网,我们计算进鱼网的时间t,记录下来,计算出鱼网的时候t,也记录下来,开一个pair的vector,把进网的时间和重量放进去,把出网的时间和负的重量放进去,然后排个序,求最大区间子段和,显然不会存在某些鱼没进网但是出网的情况,所以求的过程不会出现负数的情况,所以求最大子段和的时候不用判断和为负数的时候重制为0,还有就是用pair的时候排序第二维要插相反数,计算的时候也是计算负权值,防止由于排序引起在同一时刻有鱼进有鱼出,直接pair排序会在时间相同的情况下把负权值的鱼放前面,导致答案错误

#include 
using namespace std;#define endl '\n'
#define inf 0x3f3f3f3f
#define mod7 1000000007
#define mod9 998244353
#define m_p(a,b) make_pair(a, b)
#define mem(a,b) memset((a),(b),sizeof(a))
#define io ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
typedef long long ll;
typedef pair  pii;#define MAX 300000 + 50
int n;
ll k;struct ran{int w;double x, v;
}tr[MAX];
vectorv;
void fuck(int i, int j){if(tr[i].x > tr[j].x){if(tr[i].v >= tr[j].v)return;v.push_back(m_p((tr[i].x - tr[j].x) / (tr[j].v - tr[i].v), -tr[j].w));v.push_back(m_p((tr[i].x + k - tr[j].x) / (tr[j].v - tr[i].v), tr[j].w));}else if(tr[j].x >= tr[i].x && tr[j].x <= tr[i].x + k){v.push_back(m_p(0, -tr[j].w));if(tr[j].v > tr[i].v)v.push_back(m_p((tr[i].x + k - tr[j].x) / (tr[j].v - tr[i].v), tr[j].w));else if(tr[j].v < tr[i].v)v.push_back(m_p((tr[j].x - tr[i].x) / (tr[i].v - tr[j].v), tr[j].w));}else{if(tr[i].v > tr[j].v){v.push_back(m_p((tr[j].x-tr[i].x-k)/(tr[i].v-tr[j].v), -tr[j].w));v.push_back(m_p((tr[j].x-tr[i].x)/(tr[i].v-tr[j].v), +tr[j].w));}}
}void work(){cin >> n >> k;for(int i = 1; i <= n; ++i){cin >> tr[i].w >> tr[i].x >> tr[i].v;}int ans = 0;for(int i = 1; i <= n; ++i){v.clear();int sum = 0;for(int j = 1; j <= n; ++j){fuck(i, j);}sort(v.begin(), v.end());for(auto [x, y] : v){sum -= y;ans = max(ans, sum);}}cout << ans << endl;
}int main(){io;work();return 0;
}

相关内容

热门资讯

黄金“不灵了”,高端金饰的溢价... 古法黄金到底能不能走出脱离金价波动的独立溢价 作者:赵心怡 2026年开年,国际金价一路狂飙至近56...
朗迅科技由董事长徐振控制46%... 瑞财经 刘治颖 6月24日,杭州朗迅科技股份有限公司(以下简称:朗迅科技)深主板IPO获受理,保荐机...
两部门:2030年可再生能源制... 【两部门:2030年可再生能源制氢规模达到200万吨】财联社6月25日电,国家发展改革委、国家能源局...
原创 警... 大家好,这里是全球脉冲。 6月16日,日本央行宣布加息25个基点,政策利率上调至1%,创下31年来最...
黄金钻石回收怎么选?上海市场常... 近年来黄金价格持续走高,不少上海市民都有变现家中闲置黄金首饰、投资金条的打算。但市面上回收门店数量众...
专访火山引擎谭待:模型好对Ma... 文 | 邓咏仪 编辑 | 张雨忻 火山引擎总裁谭待 来源:火山引擎 过去三年,火山引擎总裁谭待给团...
女董事长深夜被带走,牵出金融旧... *此图由AI生成 作者| 史大郎&猫哥 来源| 是史大郎&大猫财经Pro 大半夜的,一家上市公司董事...
盯盯拍报考港交所上市:出海翻红... 撰稿|贝多 来源|贝多商业&贝多财经 6月22日,盯盯拍(深圳)技术股份有限公司(下称“盯盯拍”)递...
苏州千亿市值上市公司+1! A股“苏州板块”又诞生了一家千亿市值企业。 昨日(6月25日),苏州上市公司永鼎股份股价在昨日涨停的...
芯片股猛拉!600667,一字... 【导读】创业板指一度涨超2%,存储芯片、半导体、电子元器件等方向涨幅居前 中国基金报记者 李智 一起...
分析师:海峡收费与否已不重要 ... 来源:格隆汇APP 格隆汇6月25日|阿曼方面重申,霍尔木兹海峡未来安排不涉及通行费。美国财经网站i...
《内外贸一体化企业评价通则》团... 齐鲁晚报·齐鲁壹点记者 管悦 6月25日,《内外贸一体化企业评价通则》团体标准审查会在济南召开。该标...
提升AI智能体工作流的速度与能... 智能体工作流是一种由AI驱动的软件系统,它通过串联多个模型与外部工具来处理复杂任务,例如分析视频并回...
热搜!又有纸尿裤被曝检出甲酰胺... 来源:市场资讯 (来源:北京商报) 网友:“囤了200多包”。 近日,多个婴幼儿纸尿裤品牌“被检出...
埃森哲内部录音曝光:企业AI使... IT之家 6 月 26 日消息,科技媒体 404Media 昨日(6 月 25 日)发布博文,披露了...
FIBA期待杨瀚森表现 最新实... 北京时间6月25日消息,FIBA国际篮联公布了最新一期世界杯预选赛亚太区球队实力榜,中国男篮排在澳大...
收评:创业板指放量反弹涨2.8... 市场冲高回落后,再度震荡拉升。黄白线分化明显,权重股走势较强。量能明显放大,沪深两市成交额3.59万...
巨头财报引爆A股存储芯片板块,... 当地时间6月24日美股盘后, 美光科技(MU.US)公布截至5月31日的2026财年第三财季财报,业...
银行、消金公司助贷余额增速不得... 近日,中国证券报记者从多位业内人士处独家获悉,5月以来,多地金融监管部门对部分中小银行、消金公司下达...