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;
}

相关内容

热门资讯

原创 4... 写在文章前的声明:在本文之前的说明:本文中所列的投资信息,只是一个对基金资产净值进行排行的客观描述,...
胜宏科技港股大涨49% 做完英... 记者 陈月芹 4月21日,全球AI算力板龙头胜宏科技(02476.HK)登陆港交所,上市首日股价大涨...
永赢基金:聚焦“科技新锐”,科... 数据来源:Wind,时间统计区间为2025/1/1-2026/4/21,指数过往表现不预示未来,不构...
五大阅读趋势显现!当当网发布2... 在第31个世界读书日即将来临之际及首个全民阅读活动周期间,当当网正式发布2026国民阅读洞察报告。 ...
业绩逐季回暖 老百姓大药房一季... 上证报中国证券网讯(记者 夏子航)4月22日晚,老百姓大药房发布2025年年报和2026年一季报。今...
中国20强城市大洗牌:苏州接近... 中国的城市经济竞争格局一直在变化,每年发布的GDP数据都会对城市经济实力进行重新排列。2025年榜又...
直击金宏气体股东会:预期年内氦... 《科创板日报》4月22日讯(记者 郭辉)金宏气体日前举行2025年度股东大会。会上该公司审议了公司年...
5月1日起,俄据悉将叫停哈萨克... 据行业消息人士透露,俄罗斯将于5月1日起停止经友谊管道转运哈萨克斯坦输往德国的石油,相关调整计划已送...
深化具身智能生态布局 京东携手... 4 月 22 日,京东与国内消费级人形机器人头部企业松延动力正式达成三年期战略合作。双方将围绕产品研...
原创 帮... 先问你一个问题,美伊停火今晚到期,按常理避险情绪该升温,黄金应该涨吧?结果恰恰相反——原油涨了,黄金...
300295、600889,将... 三六五网、南京化纤,将被*ST。 公司股票自4月23日开市起停牌一天,于4月24日开市起复牌并实施退...
能源大变天!外媒:羡慕中国的石... 这一次油价突破 110 美元的能源危机,着实魔幻。如果放在十年前,没人会相信中国能在这场风波中获利,...
黄金涨跌两难,现在还能上车吗? 中新网4月22日电(记者 左雨晴) 四月以来,美伊局势反复拉扯,美联储降息预期一变再变。黄金价格在4...
“我身体健康”,库克现身员工大... 当地时间4月21日,受苹果官宣CEO换届影响,公司股价盘中下探超2%,总市值失守4万亿美元关口,收盘...
库克留下一个悬念 工程师能否拯救创新节奏? 听筒Tech(ID:tingtongtech)原创 文 | 赵 森 ...
探索消费信贷与社交支付深度融合... 腾讯这一金融产品再添新功能,4月19日,北京商报记者注意到,微信分付灰度测试转账功能引发热议,在向微...
土耳其主要银行股指早盘下跌2% 每经AI快讯,4月20日,土耳其主要银行股指早盘下跌2%。 每日经济新闻
好用的OTA代运营源头厂家 在如今竞争激烈的酒旅行业中,OTA代运营服务成为了众多酒店、民宿提升竞争力的关键。但市场上的代运营厂...
成都五一出游全国热门第三 “五一”假期临近,同程旅行最新发布的《2026“五一”旅行趋势报告》显示,今年“五一”期间成都同时位...