【wikioi】1036商务旅行

本文深入探讨了信息技术领域的多个细分技术领域,包括前端开发、后端开发、移动开发、游戏开发等,提供了关于大数据开发、开发工具、嵌入式硬件、嵌入式电路知识、嵌入式开发环境、音视频基础、音视频直播流媒体、图像处理AR特效、AI音视频处理、测试、基础运维、DevOps、操作系统、云计算厂商、自然语言处理、区块链、隐私计算、文档协作与知识管理、版本控制、项目管理与协作工具、有监督学习、无监督学习、半监督学习、强化学习、数据安全、数据挖掘、数据结构、算法、非IT技术、自动推理、人工神经网络与计算、自动驾驶、数据分析、数据工程、程序设计方法、数据库理论、代码管理工具等主题的详细解析。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述 Description

某首都城市的商人要经常到各城镇去做生意,他们按自己的路线去做,目的是为了更好的节约时间。

假设有N个城镇,首都编号为1,商人从首都出发,其他各城镇之间都有道路连接,任意两个城镇之间如果有直连道路,在他们之间行驶需要花费单位时间。该国公路网络发达,从首都出发能到达任意一个城镇,并且公路网络不会存在环。

你的任务是帮助该商人计算一下他的最短旅行时间。

输入描述 Input Description

输入文件中的第一行有一个整数N,1<=n<=30 000,为城镇的数目。下面N-1行,每行由两个整数a 和b (1<=ab<=n; a<>b)组成,表示城镇a和城镇b有公路连接。在第N+1行为一个整数M,下面的M行,每行有该商人需要顺次经过的各城镇编号。

输出描述 Output Description

    在输出文件中输出该商人旅行的最短时间。

样例输入 Sample Input
5
1 2
1 5
3 5
4 5
4
1
3
2
5
样例输出 Sample Output

7


【思路】:

典型的lca,由于是顺次经过点,所以从1出发,然后依次求每两个点之间的lca,然后过程中把deep加起来。。话说这道题被坑了好久。。从下午到晚上。。然后发现是无向边,于是要加双向边,果断推翻重写。。然后终于AC了。。

【代码】:

#include<cstdio>
#include<algorithm>


using namespace std;


struct edge{
<span style="white-space:pre">	</span>int u,v,next;
}e[30000 * 2 + 5];
int head[37000];
int deep[37000];
int p[37000][37];
int n,m,tot,k=1;


void adde(int u,int v,int k)
{
<span style="white-space:pre">	</span>e[k].next=head[u];
<span style="white-space:pre">	</span>head[u]=k;
<span style="white-space:pre">	</span>e[k].u=u;
<span style="white-space:pre">	</span>e[k].v=v;
}
void dfs(int fa,int x)
{
<span style="white-space:pre">	</span>if(deep[x]) return ;
<span style="white-space:pre">	</span>deep[x]=deep[fa]+1;
<span style="white-space:pre">	</span>p[x][0]=fa;
<span style="white-space:pre">	</span>for(int i=1;p[p[x][i-1]][i-1];i++) {
<span style="white-space:pre">		</span>p[x][i]=p[p[x][i-1]][i-1];
<span style="white-space:pre">	</span>}
<span style="white-space:pre">	</span>for(int i=head[x];i;i=e[i].next) {
<span style="white-space:pre">		</span>dfs(x,e[i].v);
<span style="white-space:pre">	</span>}
}
int lca(int u,int v)
{
<span style="white-space:pre">	</span>if(deep[u]<deep[v]) swap(u,v);
<span style="white-space:pre">	</span>if(deep[u]>deep[v]) {
<span style="white-space:pre">		</span>int dva=deep[u]-deep[v];
<span style="white-space:pre">		</span>for(int i=0;i<=24;i++) {
<span style="white-space:pre">			</span>if(dva&(1<<i)) {
<span style="white-space:pre">				</span>u=p[u][i];
<span style="white-space:pre">			</span>}
<span style="white-space:pre">		</span>}
<span style="white-space:pre">	</span>}
<span style="white-space:pre">	</span>if(u!=v) {
<span style="white-space:pre">		</span>for(int i=24;i>=0;i--) {
<span style="white-space:pre">			</span>if(p[u][i]!=p[v][i]) {
<span style="white-space:pre">				</span>u=p[u][i];
<span style="white-space:pre">				</span>v=p[v][i];
<span style="white-space:pre">			</span>}
<span style="white-space:pre">		</span>}
<span style="white-space:pre">	</span>}
<span style="white-space:pre">	</span>if(u==v) return u;
<span style="white-space:pre">	</span>else return p[u][0];
}
int main()
{
<span style="white-space:pre">	</span>scanf("%d",&n);
<span style="white-space:pre">	</span>for(int i=1;i<n;i++) {
<span style="white-space:pre">		</span>int u,v;
<span style="white-space:pre">		</span>scanf("%d%d",&u,&v);
<span style="white-space:pre">	</span>    adde(u,v,k++);
<span style="white-space:pre">	</span>    adde(v,u,k++);
<span style="white-space:pre">	</span>}
<span style="white-space:pre">	</span>deep[1]=1;
<span style="white-space:pre">	</span>for(int i=head[1];i;i=e[i].next) {
<span style="white-space:pre">		</span>dfs(1,e[i].v);
<span style="white-space:pre">	</span>}
<span style="white-space:pre">	</span>int a = 1;
<span style="white-space:pre">	</span>scanf("%d",&m);
<span style="white-space:pre">	</span>for(int i=1;i<=m;i++) {
<span style="white-space:pre">		</span>int b;
<span style="white-space:pre">		</span>scanf("%d",&b);
<span style="white-space:pre">		</span>int Lca=lca(a,b);
<span style="white-space:pre">		</span>tot+=deep[a]+deep[b]-2*deep[Lca];
<span style="white-space:pre">		</span>a=b;
<span style="white-space:pre">	</span>}
<span style="white-space:pre">	</span>printf("%d",tot);
<span style="white-space:pre">	</span>return 0;
}

附题目链接: http://codevs.cn/problem/1036/


基于C2000 DSP的电力电子、电机驱动和数字滤波器的仿真模型构建及其C代码实现方法。首先,在MATLAB/Simulink环境中创建电力电子系统的仿真模型,如三相逆变器,重点讨论了PWM生成模块中死区时间的设置及其对输出波形的影响。接着,深入探讨了C2000 DSP内部各关键模块(如ADC、DAC、PWM定时器)的具体配置步骤,特别是EPWM模块采用上下计数模式以确保对称波形的生成。此外,还讲解了数字滤波器的设计流程,从MATLAB中的参数设定到最终转换为适用于嵌入式系统的高效C代码。文中强调了硬件在环(HIL)和支持快速原型设计(RCP)的重要性,并分享了一些实际项目中常见的陷阱及解决方案,如PCB布局不当导致的ADC采样异常等问题。最后,针对中断服务程序(ISR)提出了优化建议,避免因ISR执行时间过长而引起的系统不稳定现象。 适合人群:从事电力电子、电机控制系统开发的技术人员,尤其是那些希望深入了解C2000 DSP应用细节的研发工程师。 使用场景及目标:①掌握利用MATLAB/Simulink进行电力电子设备仿真的技巧;②学会正确配置C2000 DSP的各项外设资源;③能够独立完成从理论设计到实际产品落地全过程中的各个环节,包括但不限于数字滤波器设计、PWM信号生成、ADC采样同步等。 其他说明:文中提供了大量实用的代码片段和技术提示,帮助读者更好地理解和实践相关知识点。同时,也提到了一些常见错误案例,有助于开发者规避潜在风险。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值