首页 > 其他分享 >信息学奥赛复赛复习07-CSP-J2020-03表达式前置知识点-结构体、链表、链式前向星

信息学奥赛复赛复习07-CSP-J2020-03表达式前置知识点-结构体、链表、链式前向星

时间:2024-09-30 16:35:34浏览次数:8  
标签:知识点 结点 07 int s1 链表 链式 前向星

PDF文档公众号回复关键字:20240930

1 2020 CSP-J 题目1 优秀的拆分

[题目描述]

链式前向星模板题,读入n个点,m条边,以及flag,若flag==1则图有向,否则无向。对每个点输出它的每一条边

[输入格式]

第一行三个数n,m,flag,题意如上所示 第2~1+m行,每行三个数,x,y,z,代表从x到y有一条长为z的边

[输出格式]

若flag=1则m行,flag=0则m2行,无向图中边a-b,存储 a -> b和 b -> a两条,所以为m * 2

每行三个数,即该点的编号、所指向点的编号,边的长度,先按第一个数升序排列,再以链式前向星中的顺序输出即可

其实就是i从1到n,再按顺序查找边输出即可, 特殊的,若该点无出边,单独一个空行

[输入输出样例]

输入 #1

5 5 0
1 2 5
1 4 6
2 3 7
3 5 3
3 4 1

输出 #1

1 4 6
1 2 5
2 3 7
2 1 5
3 4 1
3 5 3
3 2 7
4 3 1
4 1 6
5 3 3

输入 #2

4 3 1
1 3 6
3 4 1
2 1 3

输出 #2

1 3 6
2 1 3
3 4 1

说明/提示

对于100%的数据,m<=4000000;l<=1e9;保证图连通

2 相关知识点

1) 结构体

结构体属于用户自定义的数据类型,允许用户存储不同的数据类型

例如:

学生有姓名/年龄/分数,其中,姓名和年龄/分数是不同类型,因此不能使用数组准确存储

创建结构体

创建一个新的学生数据类型:学生包括(姓名,年龄,分数)

struct Student{
    //成员列表
 
    //姓名
    string name;
    //年龄
    int age;
    //分数
    int score;
 
};

声明结构体类型

Student s1;

结构体赋值

s1.name = "张三";
s1.age = 18;
s1.score = 100;

整体示例参考

#include <bits/stdc++.h>
using namespace std;
/*创建学生数据类型
  struct 类型名称 { 成员列表 }
*/
struct Student{
    //成员列表
    //姓名
    string name;
    //年龄
    int age;
    //分数
    int score;
}S[10];//定义以Student为类型的数组S 
 
int main(){
    Student s1; //声明结构体变量 
    //给s1属性赋值,通过.访问结构体变量中的属性
    s1.name = "张三";
    s1.age = 18;
    s1.score = 100;
    cout << "姓名:" << s1.name << "年龄:" << s1.age << "分数:" << s1.score << endl;
    Student s2 = { "李四" , 19 , 80 };//声明结构体变量并赋值 
    cout << "姓名:" << s1.name << "年龄:" << s1.age << "分数:" << s1.score << endl;
    
    //结构体数组 
    S[0].name = "王五";
    S[0].age = 30;
    S[0].score = 98;
    cout << "姓名:" << S[0].name << "年龄:" << S[0].age << "分数:" << S[0].score << endl;
    return 0;
}

2) 链表

是一种常见的数据结构,它是由一系列节点(Node)组成,每个节点包含两部分:数据域和指针域。数据域用于存储数据,指针域用于存储下一个节点的地址。链表的第一个节点称为头节点(Head),最后一个节点称为尾节点(Tail),尾节点的指针域指向空(NULL)

在结点中数据域用来存储数据元素,指针域用于指向下一个具有相同结构的结点。

因为只有一个指针结点,称为单链表

3) 链式前向星

链式前向星就是把数据以链表形式连接在一起,通过起点,把相同起点的边连接在一起,每个点为起点的所有边

3 思路分析

#include<bits/stdc++.h>
using namespace std;
const int N=4000010;
long long n,m,f,cnt,h[N];
/*
  h[] 存储对应元素起点的最大下标
  例如 边1->3  1->4 1->5  此时h[1]的值为3
  e数组 存储所有边,其中这些边相同起点通过链表串连到一起
  例如  边1->3  1->4 1->5
  上面3条边通过起点1连在一起,5->next为4,5->next为3 
*/ 
struct node{//相同起点为1个链表 
	int next,w,to;//to边连向的点 w 边的长度 next下一个结点 
}e[N];
/*
  链式前向星加边 
  加a到b的边 边权为c 
*/ 
void add(int a,int b,int c){
	cnt++;//增加一条边对应数组下标 
	e[cnt].to=b;//指向b结点 
	e[cnt].w=c;//边权为c 
	e[cnt].next=h[a];//下一个结点执向h[a] 指向前一个结点 
	h[a]=cnt;//h[a]指向当前结点  增加了1条边 ,h[a]加1 
}
int main(){
	cin>>n>>m>>f;//n个结点 m条边 f有向或无向图 
	for(int i=1;i<=m;i++){//一次输入m条边 
		int a,b,c;//从a到b的边 长度为c
		scanf("%d%d%d",&a,&b,&c);
		add(a,b,c);//加一条从a到b的边,长度为c
		if(f==0){//如果f为0说明为无向图,同时增加一条从b到a,长度为c的边 
			add(b,a,c);
		}
	}
	//输出
	for(int i=1;i<=n;i++){//i如果为0说明没有以i为起点的边,如果不为0,h[i]的值则是以i为起点的边数 
		for(int k=h[i];k;k=e[k].next) {//遍历i为起点的边 
			printf("%d %d %d\n",i,e[k].to,e[k].w);
		}
	}
	return 0;
} 

标签:知识点,结点,07,int,s1,链表,链式,前向星
From: https://www.cnblogs.com/myeln/p/18442086

相关文章

  • 【hot100-java】【合并两个有序链表】
    记忆中,两个指针合并即可。 建立哨兵节点dum/***Definitionforsingly-linkedlist.*publicclassListNode{*intval;*ListNodenext;*ListNode(){}*ListNode(intval){this.val=val;}*ListNode(intval,ListNodenext......
  • [1207]基于JAVA的家居厨具进销存智慧管理系统的设计与实现
    毕业设计(论文)开题报告表姓名学院专业班级题目基于JAVA的家居厨具进销存智慧管理系统的设计与实现指导老师(一)选题的背景和意义在当前信息化社会背景下,企业运营的高效性与精准性日益依赖于先进的信息技术和管理系统。家居厨具行业作为日常消费品市场的重要组成部分,在激烈......
  • 【数据结构】链表(2)
     【LinkedList的模拟实现】这是java中的一个集合类,可以当成链表来使用,作为链表时,它视为包含三个域,是一个双向链表【构建LinkedList框架】publicclassMyLinkedList{staticclassListNode{publicintval;publicListNodeprev;//前驱......
  • 软考知识点
    知识点:计算机的直接寻址方式直接寻址是计算机中的一种基本寻址方式,它在指令执行过程中用于确定操作数的内存地址。以下是直接寻址的相关内容和详细介绍:定义直接寻址是指在指令中直接给出操作数在内存中的地址。CPU通过这个地址直接访问内存来读取或写入操作数。特点直接性:......
  • 题解:AT_arc071_c [ARC071E] TrBBnsformBBtion
    首先看到这个奇特的转化方式和常规的数据范围,我们不难想到一定有什么规律。我们可以先想一个转化后的问题:每次询问的两个字符串都可以按照题目要求进行转化,问它们最后能不能转化成同一个字符串。这个问题很简单,我们只需要把两个字符串中的A全都换成BB,最后对\(3\)取模,看看此......
  • Python画笔案例-070 绘制通电棒棒
    1、绘制通电棒棒通过python的turtle库绘制通电棒棒,如下图:2、实现代码 绘制通电棒棒,以下为实现代码:"""通电棒棒.py注意亮度为0.5的时候最鲜艳本程序需要coloradd模块支持,安装方法:pipinstallcoloradd程序运行需要很长时间,请耐心等待。可以......
  • 203_移除链表元素
    203_移除链表元素【问题描述】给你一个链表的头节点head和一个整数val,请你删除链表中所有满足Node.val==val的节点,并返回新的头节点。示例一:输入:head=[1,2,6,3,4,5,6],val=6输出:[1,2,3,4,5]示例二:输入:head=[],val=1输出:[]示例三:输入:head=[7,7,7......
  • Hetao P2071 打字游戏 题解 [ 绿 ] [ 最小生成树 ] [ 动态规划 ] [ 编辑距离 ]
    打字游戏:MST套dp好题。首先看这个数据范围,\(O(n^4)\)把每两个字符串之前的编辑距离求一下很显然吧。然后我们观察一下每一个node的性质,发现他要么自己打完,要么从别人那里复制过来。这个就很像一棵树。建完树之后,我们就得到了一个森林。那么题目就转化为,求出一个边权之和......
  • c语言实现:链表创建、插入、删除、翻转
    #include<stdio.h>#include<stdlib.h>//链表创建typedefstructNode{intdata;structNode*next;}Node;//创建一个节点Node*createNode(intdata){Node*newNode=(Node*)malloc(sizeof(Node));newNode->data=data;newNode......
  • 代码随想录算法训练营第四天|24. 两两交换链表中的节点,19.删除链表的倒数第N个节点,面
    24.两两交换链表中的节点文章链接:https://programmercarl.com/0024.两两交换链表中的节点.html#思路视频讲解:https://www.bilibili.com/video/BV1YT411g7br代码链接:https://leetcode.cn/problems/swap-nodes-in-pairs/此题注意点:注意由于交换节点,head已经变换了位置,故最终......