909-2014-T3

news2024/11/15 23:28:36

文章目录

  • 1.原题
  • 2.算法思想
  • 3.关键代码
  • 4.完整代码
  • 5.运行结果

1.原题

有n个顶点的无向图,使用邻接矩阵作为存储结构。为减少存储空间,使用数组按照行主映射方式仅保存下三角矩阵。请给出映射公式,并编写算法计算给定顶点的度。叙述算法思想并用C++实现,说明算法的复杂性

2.算法思想

对于左下三角,直接用映射公式;对于右上三角,通过对称的特点转为左下三角,再用映射公式

3.关键代码

/**
 * @brief 压缩邻接矩阵为一维数组(左下三角)
 *
 * 将二维邻接矩阵压缩为一维数组,仅存储左下三角部分的数据。
 *
 * @param adjMatrix 二维数组表示的邻接矩阵
 * @param compressedMatrix 用于存储压缩后的矩阵的一维数组
 */
void compressAdjacencyMatrix(int adjMatrix[NUM_VERTICES][NUM_VERTICES],
                             int compressedMatrix[NUM_VERTICES * (NUM_VERTICES + 1) / 2]) {
    int index = 0;

    // 遍历二维矩阵的左下三角部分
    for (int i = 0; i < NUM_VERTICES; i++) {
        for (int j = 0; j <= i; j++) {
            // 将左下三角的数据压缩到一维数组中
            compressedMatrix[index] = adjMatrix[i][j];
            index++;
        }
    }
}

/**
 * @brief 计算给定顶点的度(利用压缩矩阵)
 *
 * 使用压缩的邻接矩阵计算给定顶点的度数。
 *
 * @param vertex 给定顶点的索引
 * @param compressedMatrix 压缩后的矩阵,存储图的连接关系
 * @return int 给定顶点的度数
 */
int calculateDegree(int vertex, int compressedMatrix[NUM_VERTICES * (NUM_VERTICES + 1) / 2]) {
    int degree = 0;

    // 遍历矩阵中与给定顶点相关的元素
    for (int i = 0; i < NUM_VERTICES; i++) {
        // i 大于 vertex 表示右上部分的矩阵
        if (i > vertex) {
            // 根据公式 i * (i + 1) / 2 + vertex 计算出压缩后的矩阵位置
            degree += compressedMatrix[i * (i + 1) / 2 + vertex];
        }
            // i 小于 vertex 表示左下部分的矩阵
        else if (i < vertex) {
            // 根据公式 vertex * (vertex + 1) / 2 + i 计算出压缩后的矩阵位置
            degree += compressedMatrix[vertex * (vertex + 1) / 2 + i];
        }
    }

    return degree;
}

4.完整代码

/**
 * @file main.c
 * @brief 实现了邻接矩阵及其操作。
 */

#include <stdio.h>

#define NUM_VERTICES 6

/**
 * @brief 压缩邻接矩阵为一维数组(左下三角)
 *
 * 将二维邻接矩阵压缩为一维数组,仅存储左下三角部分的数据。
 *
 * @param adjMatrix 二维数组表示的邻接矩阵
 * @param compressedMatrix 用于存储压缩后的矩阵的一维数组
 */
void compressAdjacencyMatrix(int adjMatrix[NUM_VERTICES][NUM_VERTICES],
                             int compressedMatrix[NUM_VERTICES * (NUM_VERTICES + 1) / 2]) {
    int index = 0;

    // 遍历二维矩阵的左下三角部分
    for (int i = 0; i < NUM_VERTICES; i++) {
        for (int j = 0; j <= i; j++) {
            // 将左下三角的数据压缩到一维数组中
            compressedMatrix[index] = adjMatrix[i][j];
            index++;
        }
    }
}

/**
 * @brief 计算给定顶点的度(利用压缩矩阵)
 *
 * 使用压缩的邻接矩阵计算给定顶点的度数。
 *
 * @param vertex 给定顶点的索引
 * @param compressedMatrix 压缩后的矩阵,存储图的连接关系
 * @return int 给定顶点的度数
 */
int calculateDegree(int vertex, int compressedMatrix[NUM_VERTICES * (NUM_VERTICES + 1) / 2]) {
    int degree = 0;

    // 遍历矩阵中与给定顶点相关的元素
    for (int i = 0; i < NUM_VERTICES; i++) {
        // i 大于 vertex 表示右上部分的矩阵
        if (i > vertex) {
            // 根据公式 i * (i + 1) / 2 + vertex 计算出压缩后的矩阵位置
            degree += compressedMatrix[i * (i + 1) / 2 + vertex];
        }
            // i 小于 vertex 表示左下部分的矩阵
        else if (i < vertex) {
            // 根据公式 vertex * (vertex + 1) / 2 + i 计算出压缩后的矩阵位置
            degree += compressedMatrix[vertex * (vertex + 1) / 2 + i];
        }
    }

    return degree;
}

/**
 * @brief 打印邻接矩阵
 * @param adjMatrix 邻接矩阵
 */
void printAdjacencyMatrix(int adjMatrix[NUM_VERTICES][NUM_VERTICES]) {
    for (int i = 0; i < NUM_VERTICES; i++) {
        for (int j = 0; j < NUM_VERTICES; j++) {
            printf("%d ", adjMatrix[i][j]);
        }
        printf("\n");
    }
}


/**
 * @brief 主函数,用于测试邻接矩阵及其操作
 */
int main() {
    int adjMatrix[NUM_VERTICES][NUM_VERTICES] = {
            {0, 1, 1, 0, 0, 0},
            {1, 0, 0, 1, 0, 0},
            {1, 0, 0, 1, 1, 0},
            {0, 1, 1, 0, 0, 1},
            {0, 0, 1, 0, 0, 1},
            {0, 0, 0, 1, 1, 0}
    };

    printf("Adjacency Matrix:\n");
    printAdjacencyMatrix(adjMatrix);

    int compressedMatrix[NUM_VERTICES * (NUM_VERTICES + 1) / 2];
    compressAdjacencyMatrix(adjMatrix, compressedMatrix);

    printf("Compressed Matrix:\n");
    for (int i = 0; i < NUM_VERTICES * (NUM_VERTICES + 1) / 2; i++) {
        printf("%d ", compressedMatrix[i]);
    }

    int vertex = 3; // 输入要计算度的顶点
    int degree;

    degree = calculateDegree(vertex - 1, compressedMatrix);
    printf("\nDegree of vertex %d is %d\n", vertex, degree);

    return 0;
}

5.运行结果

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1236566.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于ubuntu20.04安装ros系统搭配使用工业相机

基于ubuntu20.04安装ros系统搭配使用工业相机 1. ROS系统安装部署1.1更新镜像源1.1.1 备份源文件1.1.2 更新阿里源1.1.3 更新软件源 1.2 ros系统安装1.2.1 添加ros软件源1.2.2 添加秘钥1.2.3 更新软件源1.2.4 配置及更换最佳软件源1.2.5 ROS安装1.2.6 初始化rosdep1.2.7 设置环…

【Hello Go】Go语言文本文件处理

文本文件处理 字符串处理字符串操作ContainsJoinindexrepeatReplaceSplitTrimFields 字符串转换AppendFormatParse 正则表达式Json处理编码Json通过结构体生产Json通过map生产json 解码Json解析到结构体解析到interface 文件操作相关api介绍建立和打开文件关闭文件写文件读文件…

基于Apache部署虚拟主机网站

文章目录 Apache释义Apache配置关闭防火墙和selinux 更改默认页内容更改默认页存放位置个人用户主页功能基于口令登录网站虚拟主机功能基于ip地址相同ip不同域名相同ip不同端口 学习本章完成目标 1.httpd服务程序的基本部署。 2.个人用户主页功能和口令加密认证方式的实现。 3.…

Linux02 VIM编辑器

Linux02 VIM编辑器 基本上 vi/vim 共分为三种模式&#xff0c; 分别是命令模式&#xff08;Command mode&#xff09;&#xff0c;输入模式&#xff08;Insert mode&#xff09;和底线命令模式&#xff08;Last line mode&#xff09;。 三种状态进行切换 插入模式&#xff1a…

【机器学习】039_合理初始化

一、稳定训练 目标&#xff1a;使梯度值在更合理的范围内 常见方法如下&#xff1a; 将乘法变为加法 ResNet&#xff1a;当层数较多时&#xff0c;会加入一些加法进去 LSTM&#xff1a;如果时序序列较长时&#xff0c;把一些对时序的乘法做加法 归一化 梯度归一化&…

Java(五)(Object类,克隆,Objects类,包装类,StringBuilder,StringJoiner,BigDecimal)

目录 Object类 Object类的常见方法: 克隆 浅克隆 深克隆 Objects类 包装类 StringBuilder StringJoiner BigDecimal Object类 Object类是java中的祖宗类,因此,Java中所有的类的对象都可以直接使用object类提供的一些方法 Object类的常见方法: public String toStrin…

Redis-Redis持久化,主从哨兵架构详解

Redis持久化 RDB快照&#xff08;snapshot&#xff09; 在默认情况下&#xff0c; Redis 将内存数据库快照保存在名字为 dump.rdb 的二进制文件中。 你可以对 Redis 进行设置&#xff0c; 让它在“ N 秒内数据集至少有 M 个改动”这一条件被满足时&#xff0c; 自动保存一次数…

Mac- Iterm 2 (替换mac terminal 终端的下一代终端工具)

1.应用场景 主要用于macOS中作为终端工具使用, 执行终端命令, Iterm 2 (替换mac terminal 终端的下一代终端工具) 2.学习/操作 1.文档阅读 chatgpt & 其他资料 2.整理输出 2.1 是什么 Iterm 2 (替换mac terminal 终端的下一代终端工具) 2.2 为什么需要「应用场景」 macOS…

自定义类型之结构体

&#x1d649;&#x1d65e;&#x1d658;&#x1d65a;!!&#x1f44f;&#x1f3fb;‧✧̣̥̇‧✦&#x1f44f;&#x1f3fb;‧✧̣̥̇‧✦ &#x1f44f;&#x1f3fb;‧✧̣̥̇:Solitary-walk ⸝⋆ ━━━┓ - 个性标签 - &#xff1a;来于“云”的“羽球人”。…

操作系统 应用题 例题+参考答案(考研真题)

1.&#xff08;考研真题&#xff09;一个多道批处理系统中仅有P1和P2两个作业&#xff0c;P2比P1晚5ms到达&#xff0c;它们的计算和I/O操作顺序如下。 P1&#xff1a;计算60ms&#xff0c;I/O 80ms&#xff0c;计算20ms。 P2&#xff1a;计算120ms&#xff0c;I/O 40ms&…

会声会影2024出来了吗?会声会影2023怎么使用?

会声会影20247中文旗舰版 Corel VideoStudio 是一款功能强大的视频编辑软件&#xff0c;可以帮助用户创建高质量的视频作品。它提供了一系列完善的编辑功能&#xff0c;包括视频编辑、音频编辑、调色、特效、字幕、标题等。它还支持多种视频格式&#xff0c;可以将视频转换为多…

算法通关村第十二关-青铜挑战字符串

大家好我是苏麟 , 今天带来字符串专题 . 转换成小写字母 描述 : 给你一个字符串 s &#xff0c;将该字符串中的大写字母转换成相同的小写字母&#xff0c;返回新的字符串。 题目 : LeetCode 709.转换成小写字母 : 709. 转换成小写字母 分析 : 这个题可以先遍历整个字符串…

django+drf+vue 简单系统搭建 (4) 用户权限

权限控制是web中的重要组成部分。与以往的博客系统不同&#xff0c;本次工具页面仅支持注册用户。 每个注册用户都能访问到工具页面&#xff0c;并且提交自己的task来选择具体的工具来处理自己提交的文件。每个注册用户都只能访问到自己提交的task&#xff0c;而管理员则可以查…

uni-app:实现request请求的递归(设置request请求的访问次数),并且调用自定义方法给出返回值

一、效果展示 失败效果 成功效果 二、写入后端请求部分 分析 ①自定义一个模块common.js主要用于封装所有的请求函数 ②核心代码 function requestWithRetry(cmd, username, password, retryCount) {return new Promise((resolve, reject) > {uni.request({url: ip sys…

智能座舱架构与芯片- (13) 软件篇 下

四、面向服务的智能座舱软件架构 4.1 面向信号的软件架构 随着汽车电子电气架构向中央计算-域控制器的方向演进&#xff0c;甚至向车云一体化的方向迈进&#xff0c;适用于汽车的软件平台也需要进行相应的进化。 在传统的观念中&#xff0c;座舱域即娱乐域&#xff0c;座舱软…

【网络通信】浅析UDP与TCP协议的奥秘

在现代互联网中&#xff0c;UDP&#xff08;用户数据报协议&#xff09;和TCP&#xff08;传输控制协议&#xff09;是两种最常用的传输协议&#xff0c;它们被广泛应用于网络数据传输。尽管这两种协议都可以用来在网络上传输数据&#xff0c;但它们在设计目标、特点和适用场景…

Cesium 加载geojson数据类型点线面

1.获取geojson数据&#xff0c;本地新建一个.ts文件放置数据导出&#xff0c;并引入 获取geojson数据&#xff1a; DataV.GeoAtlas地理小工具系列 import { scGeojson } from ./geojson; 2.加载面 const addPolygonEvt () > {viewer.dataSources.add(Cesium.GeoJsonDataSo…

vue中data属性为什么是一个函数?

​&#x1f308;个人主页&#xff1a;前端青山 &#x1f525;系列专栏&#xff1a;Vue篇 &#x1f516;人终将被年少不可得之物困其一生 依旧青山,本期给大家带来vue篇专栏内容:vue-data属性 目录 为什么data属性是一个函数而不是一个对象&#xff1f; 一、实例和组件定义dat…

golang指针学习

package mainimport "fmt"func main() {name:"飞雪无情"nameP:&name//取地址fmt.Println("name变量的内存地址为:",&name)fmt.Println("name变量的值为:",name)fmt.Println("name变量的内存地址为:",nameP)fmt.Prin…

【CSH 入门基础 9 -- 输出 csh 脚本中每一句命令】

文章目录 输出csh脚本中每一句命令 输出csh脚本中每一句命令 在 csh 或 tcsh 脚本中&#xff0c;如果你想要输出脚本中的每一句执行&#xff0c;你可以在脚本的开头使用 -v&#xff08;verbose&#xff09;选项。这个选项会使得 shell 在执行命令前先打印出来。 要在脚本中使…