实现邻接表

题目

无向图,共有10个点,输入m条边。
输入:
10
1 2
2 4
3 4
5 6
7 9
10 1
8 9
9 5
3 7
3 8
输出:
1 : 2 10
2 : 1 4
3 : 4 7 8
4 : 2 3
5 : 6 9
6 : 5
7 : 9 3
8 : 9 3
9 : 7 8 5
10 : 1

代码:

#include <iostream>
#include<vector>
using namespace std;
int main() {vector<int>G[11];int m;cin>>m;for(int i=0;i<m;++i){int a,b;cin>>a>>b;G[a].push_back(b);G[b].push_back(a);}for(int i=1;i<=10;i++){cout<<i<<" : ";for(int j=0;j<G[i].size();j++){cout<<G[i][j]<<" ";}cout<<endl;}return 0;
}

题目:

带权图
10
1 2 3
2 4 4
3 4 2
5 6 1
7 9 0
10 1 -7
8 9 -4
9 5 10
3 7 11
3 8 20
输出:
(1, 2, 3)
(1, 10, -7)
(2, 1, 3)
(2, 4, 4)
(3, 4, 2)
(3, 7, 11)
(3, 8, 20)
(4, 2, 4)
(4, 3, 2)
(5, 6, 1)
(5, 9, 10)
(6, 5, 1)
(7, 9, 0)
(7, 3, 11)
(8, 9, -4)
(8, 3, 20)
(9, 7, 0)
(9, 8, -4)
(9, 5, 10)
(10, 1, -7)

代码:

#include <iostream>
#include <vector>
using namespace std;
struct node{int v,w;
};
vector<node> G[11];
void insert1(int u,int v,int w){node temp;temp.v=v;temp.w=w;G[u].push_back(temp);
}
void insert2(int u,int v,int w){insert1(u,v,w);insert1(v,u,w);
}
void input(){int m;cin>>m;for(int i=0;i<m;++i){int u,v,w;cin>>u>>v>>w;insert2(u,v,w);}
}
void output()
{for(int i=1;i<=10;++i){for(int j=0;j<G[i].size();j++){cout<<"("<<i<<", "<<G[i][j].v<<", "<<G[i][j].w<<")"<<endl;}}
}
int main() {input();output();return 0;
}

链表实现

const int M = 1000000;
const int N = 10000;
struct edge {int v, d, next;
} e[M];
int p[N], eid;
void init() {  // 初始化,在建图之前必须进行memset(p, -1, sizeof(p));eid = 0;
}
void insert(int u, int v, int d) {  // 插入单向边e[eid].v = v;e[eid].d = d;e[eid].next = p[u];p[u] = eid++;
}
void insert2(int u, int v, int d) {  // 插入双向边insert(u, v, d);insert(v, u, d);
}
void output(int n) {  // 输出整张图中的所有边for (int i = 0; i < n; i++) {for (int j = p[i]; j != -1; j = e[j].next) {  // 遍历从 i 连出的所有边cout << i << "->" << e[j].v << ", " << e[j].d << endl;}}
}

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

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

相关文章

java 重复代码优化_Java代码优化

优化实践1.try{}catch(){}使用1)查询中不要使用try{}catch(){}语句2)循环中不要使用try{}catch(){}语句3)异常处理不要对于所有的异常捕获都使用Exception&#xff0c;最好是捕获对应的异常类型&#xff0c;处理日志方式&#xff1a;1、打印错误日志2、调用错误业务逻辑处理函数…

c++变量,对象

变量&#xff0c;对象 变量&#xff08;variable&#xff09;&#xff1a;提供一个具名的、可供程序操作的存储空间。 对象&#xff08;object&#xff09;&#xff1a;一块能存储数据并具有某种类型的内存空间。 在是否命名上&#xff0c;有的人把命了名的对象称为变量。在…

java 微信 回复_微信java 开发2 发送文本消息并回复

因为用的是springmvc首先看一下统一接收接口&#xff0c;dispatchWeiXinRequest发放用于区别get还是postRequestMapping(value "/dispatcher")ResponseBodypublic void dispatcher(HttpServletRequest request,HttpServletResponse response) throws ParseException…

java 06_JAVA06 数组

1.设计思路&#xff1a;首先设置长度为10的数组&#xff0c;设置Random引用对象&#xff0c;在循环中生成一个随机数存储在数组中&#xff0c;累加和&#xff0c;利用对话框输出结果。2.程序流程图&#xff1a;3.源程序代码&#xff1a;1 //2016/11/062 //随机生成10个数&#…

java service 事物_Service 事务(JdbcUtils 升级)

1. DAO 事务// 在 DAO 中处理事务真是"小菜一碟"public void xxx(){Connection con null;try{con JdbcUtils.getConnection();con.setAutoCommit(false); // 开启事务QueryRunner qr new QueryRunner();String sql ...;Object[] params ...;qr.update(con,sql,p…

c++ const限定符

const限定符 const对像一旦创建&#xff0c;其值就不能发生改变。const对象必须初始化 const int i get_size();//正确&#xff0c;运行时初始化。 const int j 1;//正确&#xff0c;编译时初始化。j 2;//错误&#xff0c;j是一个常量&#xff0c;试图对其赋值行为将发生错误…

java 8.0 sinffer_jpcap 配置方法,问题解决,模拟sniffer程序。(附JAVA程序,jar,dll包等环境)...

一、 Eclipse环境下安装与配置Jpcap相关源程序、jpcap jar包&#xff0c;dll包&#xff0c;帮助文档。1、下载安装winpcap2、jpcap官方文件中lib包下&#xff0c;有两个文件&#xff0c;jpcap.dll和jpcap.jar。jpcap.dll-->JAVA安装路径/jre1.6.0_06/bin (JRE目录)jpcap.j…

c++ 参数传递

参数传递&#xff1a; 形参&#xff08;parameter&#xff09;和实参&#xff08;argument&#xff09;&#xff1a; int num (int a, int b); int num (int a, int b){return ab; }//在函数的声明或者定义里&#xff0c;由由0个或多个形参组成的列表。int main(){int n1,m1;co…

c++定义成员函数

1.定义和声明成员函数的方式和普通函数差不多。成员函数的声明必须在类的内部&#xff0c;他的定义则即可以在类的内部也可以在类的外部。非成员函数的定义和声明都在类的外部。 struct Sales_data{std::string isbn() const { return bookNo; }double avg_price() const;std:…

java拖动图片拼图_求教,我的这个拼图程序中的移动图片的改怎么做

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼public class button extends JPanel implements MouseListener, ActionListener {/****/private static final long serialVersionUID 1L;private JButton[] button;private ImageIcon[] puzzlep;private JButton kbbutton;priva…

c++函数返回值是一个引用

函数返回值是一个引用的情况&#xff1a; 1.值是如何被返回的&#xff1a; 返回的值用于初始化调用点的一个临时量&#xff0c;该临时量就是函数调用的结果。 如果函数返回引用&#xff0c;则该引用仅是它所引对象的一个别名。 2.不能返回局部对象的引用或指针&#xff1a;…

java视频压缩 lz4_一种视频序列帧的压缩方法、解压方法及装置与流程

技术特征&#xff1a;1.一种视频序列帧的压缩方法&#xff0c;其特征在于&#xff0c;包括&#xff1a;在视频帧数据压缩时&#xff0c;对解析到的第一帧视频帧数据使用lz4算法进行压缩并保存至视频文件中&#xff1b;对之后解析到的每一帧视频帧数据都与之前一帧视频帧数据进行…

c++ 构造函数

构造函数&#xff1a; 类通过一个或几个特殊的成员函数来控制其对象的初始化进程&#xff0c;这些函数叫构造函数。构造函数的任务是初始化类对象的数据成员。 构造函数名字和类名相同&#xff0c;构造函数没有返回类型。构造函数也有一个可能为空的参数列表和一个可能为空的…

js java post提交_如何从Express.js发送Post请求到另一个服务器(Java)?

小编典典您正在重复请求&#xff0c;并为发布请求重新分配变量。我已经更新了您的代码并与requestb.in一起对其进行了测试var express require(express);var querystring require(querystring);var http require(http);var app express();app.get(/, function (req, res) {…

c++ 访问控制与封装

访问控制与封装 文章目录访问说明符&#xff1a;友元&#xff1a;封装好处&#xff1a;class Sales_data{public://作为接口的一部分&#xff0c;构造函数和部分成员函数isbn&#xff0c;combine紧跟在public说明符之后。Sales_data() default;Sales_data(const std::string &…

c++ 命名空间的using声明

命名空间的using声明&#xff1a; 除了内置类型之外&#xff0c;c语言还定义了一个内容丰富的抽象数据类型库。 访问库中名字的一个简单方法就是通过using。 我们用到的库函数基本上都属于命名空间std&#xff0c;可以通过::&#xff08;作用域操作符&#xff09;从左侧作用…

mysql工作中遇到的问题_MySQL工作中遇到的问题记录

1&#xff1a;log_slave_updates:从库1搭建级联从库2&#xff0c;从库1需要开启log_slave_updates&#xff0c;修改/etc/my.cnf&#xff0c;增加一行log_slave_updates1&#xff0c;重启数据库。http://blog.itpub.net/12679300/viewspace-1319263/2&#xff1a;ERROR 1418 (HY…

java 基本格式

java基本格式&#xff1a; 所有的java程序必须放在一个类之中才可以执行。 主方法main是整个java程序的入口&#xff0c;所有程序都是从public static void main(String[] args)开始运行的。 类定义有两种形式&#xff1a; public class:文件名和类名一致。每一个*.java文件…

用java画海绵宝宝_java 方法的重载

方法的重载&#xff1a;一个类中允许出现一个以上的同名方法&#xff0c;必须保证同名方法的参数列表不同好处&#xff1a;方便阅读&#xff0c;优化程序设计重载规则&#xff1a;重载方法名相同&#xff0c;但每个重载方法都必须有一个独一无二的参数类型列表&#xff0c;方法…

Java 构造方法

Java构造方法&#xff1a; 通过构造方法&#xff0c;在对象最初被创建时就完成对其成员变量的初始化。 构造方法特点&#xff1a; 构造方法名称和类名相同。构造方法不返回任何数据&#xff0c;也不用void声明。在创建对象时&#xff0c;系统自动调用类的构造方法。构造方法…