非常好名次,使我的 \(1\) 旋转

四发罚时应该是这次比赛最唐的东西了,没有就进前一千了

A.Buy a Pen

特判秒了,懒得打三种 ans=,所以就把不能选的那个赋值成无穷大了

#include<bits/stdc++.h>
using namespace std;
#define speed ios::sync_with_stdio(false);
#define tests int cases;cin>>cases;while(cases--)
int main(){
speed
int a,b,c;
cin>>a>>b>>c;
string x;
cin>>x;
if(x=="Red") a=101;
if(x=="Green") b=101;
if(x=="Blue") c=101;
cout<<min({a,b,c})<<endl;
}

B.Right Triangle

讲个好玩的,这个题需要求两点 \((x_1,y_1),(x_2,y_2)\) 之间的坐标,然后我先是写了个这个

dis[1]=sqrt(x[1]*x[1]+y[1]*y[1]);

后面求勾股定理的时候发现好像不对,这好像是勾股定理,所以改成下面这样:

dis[1]=sqrt((x[1]-x[2])*(y[1]-y[2]));

这玩意 re 了,我也没干别的,唯一想到的就是给负数开根了,一看果然是负的...

#include<bits/stdc++.h>
using namespace std;
#define speed ios::sync_with_stdio(false);
#define tests int cases;cin>>cases;while(cases--)
const double eps=1e-8;
int main(){
speed
int x[4],y[4];
cin>>x[1]>>y[1]>>x[2]>>y[2]>>x[3]>>y[3];
double dis[4];
dis[1]=sqrt((x[1]-x[2])*(x[1]-x[2])+(y[1]-y[2])*(y[1]-y[2]));
dis[2]=sqrt((x[2]-x[3])*(x[2]-x[3])+(y[2]-y[3])*(y[2]-y[3]));
dis[3]=sqrt((x[3]-x[1])*(x[3]-x[1])+(y[3]-y[1])*(y[3]-y[1]));
// cout<<dis[1]<<" "<<dis[2]<<" "<<dis[3]<<endl;
if(dis[3]<dis[1]) swap(dis[3],dis[1]);
if(dis[3]<dis[2]) swap(dis[3],dis[2]);
if(abs(dis[1]*dis[1]+dis[2]*dis[2]-dis[3]*dis[3])<=eps) cout<<"Yes"<<endl;
else cout<<"No"<<endl;'
}

还有一个就是 eps 的问题,这个题刻意卡了直接判等,handmade 测试点会全 WA,不过我恰好改一次都改对了,所以没吃第二发罚时

C.Sum = 0

稍微有点意思,首先算出所有左边界的和,再算出所有右边界的和,注意到左边界一定是最小的和,而右边界一定是最大的,因此有解的充要条件应为 \(min\le 0,max\ge 0\)

然后就再扫一遍,从最大的和中减掉(每次都改一个右边界为左边界),如果当前最大和减不动了,那就把它减到 \(0\) 输出,后面的正常输出右边界即可.

#include<bits/stdc++.h>
using namespace std;
#define speed ios::sync_with_stdio(false);
#define tests int cases;cin>>cases;while(cases--)
const double eps=1e-8;
#define int long long
int n;
int l[200001],r[200001];
int maxn,minn;
signed main(){
speed cin>>n;
for(int i=1;i<=n;++i){
cin>>l[i]>>r[i];
maxn+=r[i];
minn+=l[i];
}
if(maxn<0 or minn>0){
cout<<"No"<<endl;
return 0;
}
cout<<"Yes"<<endl;
for(int i=1;i<=n;++i){
if(maxn>0){
if(maxn>=(r[i]-l[i])){
maxn-=r[i]-l[i];
cout<<l[i]<<" ";
}
else{
cout<<r[i]-maxn<<" ";
maxn=0;
}
}
else if(maxn==0){
cout<<r[i]<<" ";
}
}
}

D.Shortest Path 3

DIJ 版本的考试题,和我考试打的那份错解一个思路

#include<bits/stdc++.h>
using namespace std;
#define int long long
int cnt;
int n,m,x;
int a[500000];
struct shabicth{
int q,dat;
bool operator < (const shabicth &a) const{
return dat>a.dat;
}
};
struct node{
int to,w,next;
}edge[600000];
int head[200010];
bool f[200100];
int dis[200010];
int sum[2000];
int sbcth[7000][3];
void add(int u,int v,int w){
edge[++cnt].next=head[u];
edge[cnt].to=v;
edge[cnt].w=w;
head[u]=cnt;
}
void dij(int s){
priority_queue<shabicth> qq;
int x,y;
shabicth cc;
cc.q=s;
cc.dat=a[s];
qq.push(cc);
memset(dis,0x7f,sizeof(dis));
memset(f,0,sizeof(f));
dis[s]=a[s];
while(!qq.empty()){
x=qq.top().q;
y=qq.top().dat;
qq.pop();
if(!f[x]){
f[x]=true;
for(int i=head[x];i;i=edge[i].next){
cc.q=edge[i].to;
if(!f[cc.q]&&dis[cc.q]>y+edge[i].w+a[cc.q]){
dis[cc.q]=y+edge[i].w+a[cc.q];
cc.dat=dis[cc.q];
qq.push(cc);
}
}
}
}
}
signed main(){
cin>>n>>m;
for(int i=1;i<=n;i++){
cin>>a[i];
dis[i]=a[i];
}
for(int i=1;i<=m;i++){
int x,y,num;
cin>>x>>y>>num;
add(x,y,num);
add(y,x,num);
}
dij(1);
for(int i=2;i<=n;i++) cout<<dis[i]<<' ';
}

E.Count Arithmetic Subsequences

窝太菜辽,想了半条才明白 Arithmetic Subsequences 是等差数列的意思

日文阅读理解

上の解法は更に高速化することができます.以下の状態を持つ DP を考えます.

\(dp[i][l][d]=\) 初項 \(A_i\),長さ \(l(l≥2)\),公差 \(d\) であるような等差数列の個数

\(i\) の降順に見ていき,初項 \(A_i\) を固定します.第 \(2\) 項 \(A_j\ (i<j)\) と長さ \(l\) を全探索します.このとき,公差は \(d=A_j−A_i\) と定まります. \(l=2\) の場合は (\(A_i,A_j\) ) が長さ \(2\) の等差数列なので, \(dp[i][2][d]\) に \(1\) を足します. \(l≥3\) の場合,初項 \(A_i\) ,長さ \(l\),公差 \(d\) の等差数列は,初項 \(A_j\) ,長さ \(l−1\),公差 \(d\) の等差数列の先頭に \(A_i\) を追加したものとなっています.よって, \(dp[i][l][d]\) に \(dp[j][l−1][d]\) を足します.

公差 \(d\) は \(10^9\) 程度の大きな値を取りうるため,\(d\) に関する添字は連想配列で持てばよいです.C++ で map を使用した場合,時間計算量は \(O(N^3logN)\) となります.

または,各 \(i\) についてあり得る公差をあらかじめ列挙して座標圧縮しておけば,\(d\) に関する添字を配列で持つことができます.この場合,時間計算量は \(O(N^3)\) です.

没用翻译读懂了,大概就是开一个 DP 记录出项,长度,公差三个参数,这样就能唯一确定一个等差数列,再用 map 判重.

赛时差不多打出来了,因为这个题 \(n\) 只有 \(80\),赛时打的时候我是考虑枚举等差数列前两项,然后利用公差扫一遍后面的数,统计答案就行了.

此外 \(ans_{1}=n,ans_{2}=\frac{n\times (n-1)}{2}\)

G.Count Substring Query

没想到考了 AC 自动机板子题,板子不会打就偷了一份

后记

谴责一款强迫我看日文题解的网站



トヨタ自動車プログラミングコンテスト2024#7(ABC 362)的更多相关文章

  1. 【日语】日语单词N3_N4_N5

    日语单词N3_N4_N5 单 词 讲 解 あ行单词 ああ:0[副]那样.那种 例句:ああ言うことはしないほうがいい.那样的事情最好不做. 電車の窓からごみを棄てているああ言うことはしないほうがいい. ...

  2. 日语单词N3_N4_N5

    单 词 讲 解 あ行单词 ああ:0[副]那样.那种 例句:ああ言うことはしないほうがいい.那样的事情最好不做. 電車の窓からごみを棄てているああ言うことはしないほうがいい. 挨拶(あいさつ):① 寒暄 ...

  3. Universal Asynchronous Receiver/Transmitter

    USART簡介與特性 NRZ標準資料格式(Mark/Space) 半雙工/全雙工 Synchronous 同步傳輸 CLOCK SKEW Asynchronous 非同步傳輸 半/全雙工.同步/非同步 ...

  4. PMP用语集

    AC actual cost 实际成本 ACWP actual cost of work performed 已完工作实际成本 BAC budget at completion 完工预算 BCWP b ...

  5. Rong's Portfolio

    車架貼標設計 Velocite SYN frame decals 以簡潔設計的原則,分別依公路車.登山車.電動車的屬性設計表面塗裝曲線,針對車架特殊造型設計貼標突顯其功能,並搭配品牌基本色與市場偏好色 ...

  6. Python 基礎 - 元組與簡易購物車實做

    tuple(元組) 其實跟列表差不多,也是存一組數,只不過是它一旦建立了,就不能修改了,只能做 切片 跟 查詢,所以只叫 只讀列表 語法: name = ("Rogers", &q ...

  7. LED驅動電路概述

    LED是一種固體光源,當它兩端加上正向電壓,半導體中的少數載流子和多數載流子發生復合,放出的過剩能量將引起光子發射.采用不同的材料,可制成不同顏色有 發光二極管 . 隨著對LED研究的進一步深入,其光 ...

  8. PID控制動手玩玩看

    PID控制動手玩玩看 PID三個參數到底該怎麼調才好,真的是一門藝術. 雖然在Marlin韌體內有提供自動測量的功能,但是測得的結果,不見得能令人滿意,還是需要調整.可是到底該怎麼調整?從哪個參數開始 ...

  9. Word 中的橫式格式方程式和數學自動校正

    以橫式格式輸入方程式 您可以使用數學自動校正程式碼,迅速輸入大多數的方程式.例如,若要對齊方程式陣列,您可以使用 @ 和 &,如下所示: \eqarray(x+1&=2@1+2+3+y ...

  10. 【IOS】将一组包含中文的数据按照#ABC...Z✿分组

    上一篇文章[IOS]模仿windowsphone列表索引控件YFMetroListBox里面 我们一步步的实现了WindowsPhone风格的索引. 但是有没有发现,如果你要实现按照字母排序,你还得自 ...

随机推荐

  1. Python 阿里云OSS文件上传下载与文件删除及检索示例

    阿里云OSS文件上传下载与文件删除及检索示例 实践环境 运行环境: Python 3.5.4 CentOS Linux release 7.4.1708 (Core)/Win10 需要安装以下类库: ...

  2. ElementUI Dialog 结合Vue实现对话框body“二分”布局

    Dialog 结合Vue实现对话框body"二分"布局 需求描述 如下图, 把对话框body内容部分,分成上下两部分,其中上部分高度根据窗口大小动态调整,如果内容过多,则出现滚动条 ...

  3. Java代码实现七夕魔方照片墙

    创建一个七夕魔方照片墙是一个相对复杂的任务,涉及到前端展示和后端数据处理.在这里,我会提供一个简化的Java后端示例,用于生成一个模拟的"照片墙"数据模型,并给出一个基本的前端HT ...

  4. cgroup限制进程cpu

    编写一个死循环脚本 [root@workstation ~]# cat circle.sh #!/bin/bash a=1 while true do let a++ done 查看top 使用cgr ...

  5. 对比python学julia(第一章)--(第六节)数字黑洞

    6.1. 问题描述 6174数字黑洞是印度数学家卡普雷卡尔于1949年发现的,又称为卡普雷卡尔黑洞,其规则描述如下. 任意取一个4位的整数(4个数字不能完全相同),把4个数字由大到小排列成一个大的数, ...

  6. 【DataBase】局域网访问Windows系统下的MySQL8

    Windows服务主机已经安装好MySQL8并且配置了用户密码 MySQL8更改用户密码: ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' ...

  7. (待续)【转载】 Deep Reinforcement Learning Doesn't Work Yet(这里有一篇深度强化学习劝退文)

    原文: https://www.alexirpan.com/2018/02/14/rl-hard.html ============================================== ...

  8. 在进行神经网络训练时需要使用的显存空间大小的预估——300MB的神经网络在训练时最少需要占用多大的显存空间

    以Tensorflow为例. ======================================= 神经网络(TensorFlow举例)在GPU中训练时需要占用的内存大概有下面几部分组成: ...

  9. [工具分享]ClipX超级粘贴板,超级好用

    1.背景 话说粘贴.复制是码农们的必备核心技能, 普通码农们当然已经熟练的掌握了普通的粘贴复制.... 但是,你不知道的是,牛逼的架构师已经会使用超级粘贴板了,功能非常强大 ............. ...

  10. [简单] 树上的dfs & bfs_洛谷P5908 猫猫和企鹅

    题目链接https://www.luogu.com.cn/problem/P5908 题目大意: \[\begin{align*} & 给定n个点构成一颗树 每条边val=1\\ & ...