hdu1102 Constructing Roads 最小生成树Prim

本文出自:http://blog.csdn.net/svitter转载请注明出处;

原题地址:http://acm.hdu.edu.cn/showproblem.php?pid=1102



题意:有N个村庄,用1到N标号,现在你需要建路连接村庄,使得建的路最短。一开始告诉你村庄的个数,然后给你一个邻接矩阵,然后再给你个q,告诉你有多少条路已经修了,然后告诉你哪两个村庄的路修了。

题解:最小生成树水题一发。。小难点在于后面的已经建成的村庄路,存在路则设置路径为0即可。

#include <iostream>
#include <stdio.h>
#include <string.h>

#define INF 0x1f1f1f1f
using namespace std;

int cost[110][110];
int low[110];
bool vis[110];
int n;
int i, j;
int prim()
{
    memset(low, 0, sizeof(low));
    memset(vis, 0, sizeof(vis));

    int i, j, p;
    int min, res = 0;
    vis[1] = 1;
    for(i = 2; i <= n; i++) //low每个点到生成树的最小距离, vis表示一个点是否加入到生成树中
        low[i] = cost[1][i];
    for(i = 2; i <= n; i++)
    {
        min = INF, p = -1;
        for(j = 1; j <= n; j++)
        {
            if(0 == vis[j] && min > low[j])
            {
                min = low[j];
                p = j;
            }
        }

        //min == INF 说明找不到能够加入的点了,说明图是不连通的
        if(min == INF)
            return -1;

        res += min;
        vis[p] = 1;

        for(j = 1; j <= n; j++)
        {
            if(0 == vis[j] && low[j] > cost[p][j])
            {
                low[j] = cost[p][j];
            }
        }
    }//end of i;
    return res;
}


void ace()
{
    int i, j;
    int v1, v2;
    int q;
    while(cin >> n)
    {
        for(i = 1; i <= n; i++)
        {
            for(j = 1; j <= n; j++)
            {
                scanf("%d", &cost[i][j]); // input the map;
            }
        }

        cin >> q;
        for(i = 0; i < q; i++)
        {
            scanf("%d%d", &v1, &v2);
            cost[v1][v2] = 0;
            cost[v2][v1] = 0;
        }

        cout << prim() << endl;
    }
}

int main()
{
    ace();
    return 0;
}


转载于:https://my.oschina.net/u/1017188/blog/333845

《RSMA与速率拆分在有限反馈通信系统中的MMSE基预编码实现》 本文将深入探讨RSMA(Rate Splitting Multiple Access)技术在有限反馈通信系统中的应用,特别是通过MMSE(Minimum Mean Square Error)基预编码进行的实现。速率拆分是现代多用户通信系统中一种重要的信号处理策略,它能够提升系统的频谱效率和鲁棒性,特别是在资源受限和信道条件不理想的环境中。RSMA的核心思想是将用户的数据流分割成公共和私有信息两部分,公共信息可以被多个接收器解码,而私有信息仅由特定的接收器解码。这种方式允许系统在用户间共享信道资源,同时保证了每个用户的个性化服务。 在有限反馈通信系统中,由于信道状态信息(CSI)的获取通常是有限且不精确的,因此选择合适的预编码技术至关重要。MMSE预编码是一种优化策略,其目标是在考虑信道噪声和干扰的情况下最小化期望平方误差。在RSMA中,MMSE预编码用于在发射端对数据流进行处理,以减少接收端的干扰,提高解码性能。 以下代码研究RSMA与MMSE预编码的结合以观察到如何在实际系统中应用RSMA的速率拆分策略,并结合有限的反馈信息设计有效的预编码矩阵。关键步骤包括: 1. **信道模型的建立**:模拟多用户MIMO环境,考虑不同用户之间的信道条件差异。 2. **信道反馈机制**:设计有限反馈方案,用户向基站发送关于信道状态的简化的反馈信息。 3. **MMSE预编码矩阵计算**:根据接收到的有限反馈信息,计算出能够最小化期望平方误差的预编码矩阵。 4. **速率拆分**:将每个用户的传输信息划分为公共和私有两部分。 5. **信号发射与接收**:使用预编码矩阵对信号进行处理,然后在接收端进行解码。 6. **性能评估**:分析系统吞吐量、误码率等性能指标,对比不同策略的效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值