poj 2457 dijkstra(星星之间买牛奶)

本文介绍了一种解决商品交换问题的方法,通过构建图模型,利用最短路径算法(Dijkstra算法和BFS算法)来找出从一种商品到另一种商品所需的最少交换次数,并输出具体的交换顺序。

题意:cows 想用自己手上的商品(编号为1)通过多次交换得到想要的商品(编号为k),给出两种商品的交换关系,求出至少有多少种商品经过交换,输出交换的顺序。

思路:最短路。相当于求从1商品到k商品的最短路径,中间再记录一下结点信息。

 

#include <stdio.h>
#include <string.h>
#define INF 0xfffffff
#define N 1005
#define M 50005
struct edge{
	int y,w,next;
}e[M];
int used[N],dis[N],first[N],pre[N];
int n,m,top;
void add(int x,int y){
	e[top].y = y;
	e[top].w = 1;
	e[top].next = first[x];
	first[x] = top++;
}
int dijkstra(){
	int i,j,now,min;
	memset(used,0,sizeof(used));
	for(i = 1;i<=n;i++)
		dis[i] = INF;
	dis[1] = 0;
	for(i = 1;i<=n;i++){
		min = INF;
		for(j = 1;j<=n;j++){
			if(!used[j] && dis[j]<min){
				min = dis[j];
				now = j;
			}
		}
		if(min == INF)
			break;
		used[now] = 1;
		for(j = first[now];j!=-1;j=e[j].next){
			if(!used[e[j].y] && dis[now]+e[j].w < dis[e[j].y]){
				dis[e[j].y] = dis[now]+e[j].w;
				pre[e[j].y] = now;
			}
		}
	}
	if(dis[n] == INF)
		return -1;
	return dis[n]+1;
}
void print(int i){
	if(i>1)
		print(pre[i]);
	printf("%d\n",i);
}
int main(){
	freopen("a.txt","r",stdin);
	while(scanf("%d %d",&m,&n)!=EOF){
		int i,a,b;
		top = 0;
		memset(first,-1,sizeof(first));
		for(i = 0;i<m;i++){
			scanf("%d %d",&a,&b);
			add(a,b);
		}
		i = dijkstra();
		printf("%d\n",i);
		if(i!=-1)
			print(n);
	}
	return 0;
}

其实用bfs即可。

#include <cstdio>
#include <cstring>
#include <string>
#include <vector>
#include <queue>
using namespace std;
#define N 1005
#define INF 0x7fffffff
struct edge{
    int y,next;
}e[50005];
int first[N], dis[N], pre[N];
int top;
bool used[N];
void add(int x, int y){
    e[top].y = y;
    e[top].next = first[x];
    first[x] = top++;
}
void bfs(int n){
    queue<int> q;
    q.push(1);
    memset(used, false, sizeof(used));
    memset(dis, 0, sizeof(dis));
    memset(pre, -1, sizeof(pre));
    used[1] = true;
    while(!q.empty()){
        int pos = q.front();
        q.pop();
        for (int j = first[pos]; j!=-1; j = e[j].next){
            if(!used[e[j].y]){
                used[e[j].y] = true;
                dis[e[j].y] = dis[pos]+1;
                pre[e[j].y] = pos;
                if(e[j].y == n)
                    return;
                q.push(e[j].y);
            }
        }
    }
}
void print(int n){
    if(n == -1)
        return;
    print(pre[n]);
    printf("%d\n", n);
}
int main(){
    int n,m;
    while(scanf("%d %d", &m, &n) != EOF){
        int a,b;
        top = 0;
        memset(first, -1, sizeof(first));
        while(m--){
            scanf("%d %d",&a, &b);
            add(a, b);
        }
        bfs(n);
        if (pre[n] == -1){
            printf("-1\n");
        }else{
            printf("%d\n", dis[n]+1);
            print(n);
        }
    }
    return 0;
}

 

 

 

 

打开链接下载源码: https://pan.quark.cn/s/a4b39357ea24 QT框架是由Qt公司设计的一种跨平台C++图形用户界面应用程序开发工具包,该框架被广泛地应用于桌面电脑、移动设备以及嵌入式系统等领域。QTableView作为QT框架中的一个核心组件,其主要功能是用于展示表格形式的数据,并且常常与QAbstractItemModel或QSqlTableModel等模型类协同工作。在QTableView中嵌入自定义组件,例如按钮,能够实现更加多样化的用户交互功能。 在QT框架环境下,若想在QTableView的一列中嵌入两个按钮,我们需要掌握以下几个关键的技术要点: 1. **QTableView**:QTableView是QTableView类的一个实例,它提供了一个二维的表格视图界面,可以用来展示和编辑模型中的数据。QTableView能够显示由QAbstractItemModel子类所提供的数据,例如QStandardItemModel或QAbstractTableModel等。 2. **QTableWidgetItem**:在QTableView中,QTableWidgetItem是构成表格单元格的基本对象,它用于表示表格中每一行每一列的数据。在默认情况下,QTableView仅能展示文本信息,但通过继承QTableWidgetItem并重新绘制,我们可以实现自定义的内容,比如嵌入按钮。 3. **自定义视图项**:若要在单元格内部嵌入两个按钮,我们需要开发一个自定义的QTableWidgetItem子类,该子类中包含两个QPushButton。这个子类需要重写paintEvent()方法以绘制按钮,并且实现必要的信号和槽机制来处理按...
内容概要:本文系统研究了LLC谐振变换器的变频移相混合控制模型,并基于Simulink平台进行了完整的仿真实现。文章首先阐述了LLC谐振变换器在高频高效电源转换中的工作原理与技术优势,重点提出了一种融合变频控制与移相控制的混合调控策略,旨在拓宽输出调节范围并提升系统的动态响应能力与运行效率。通过建立精确的系统数学模型,设计了复合控制框图,并在Simulink中搭建仿真系统,全面验证了该控制策略在不同负载条件和输入电压波动下的稳定性、效率表现及软开关实现能力。仿真结果表明,所提出的混合控制方法能有效降低开关损耗,提高能量转换效率,具备良好的工程应用前景。; 适合人群:具备电力电子技术、自动控制理论基础,熟悉Simulink仿真环境,从事高频电源变换器、谐振变换器设计与优化的研究生、科研人员及电力电子领域工程技术人员。; 使用场景及目标:①用于高性能LLC谐振变换器控制系统的设计与动态性能优化;②为软开关技术在电力电子变换器中的应用提供仿真验证平台;③支撑相关课题的科研论文撰写、项目开发与创新方案验证。; 阅读建议:建议读者结合Simulink仿真模型文件进行同步操作,深入理解变频与移相控制的协调机制、控制环路设计及关键参数整定方法,重点关注软开关实现条件与系统效率优化路径,以促进理论研究向实际工程应用的转化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值