首页IT科技立体状星星(指向立体星(随便起的名)的建立与使用)

立体状星星(指向立体星(随便起的名)的建立与使用)

时间2025-06-17 08:54:55分类IT科技浏览4875
导读:在图论中,我们经常使用不同种的数据结构来储存图的信息,同时要适应算法的需要;...

在图论中             ,我们经常使用不同种的数据结构来储存图的信息                    ,同时要适应算法的需要;

其中较为节省内存的包括了链式前向星和邻接表       ,但是对于最基本的最短路初学者一般用不到      ,因此                    ,我在此介绍一种基于结构体的储存方式——“指向立体星             ”

一 指向立体星的搭建 struct ver { int no;//节点编号 int dat;//点权 int tnum;//出度 int to[N];//通往的点(储存的数量应该等于tnum) int k1[N];//出度的边权 int edge1[N];//出度的边的编号 int fnum;//入度 int from[N];//入度边的起始点 int k2[N];//入度的边权 int edge2[N];//入度的边的编号 }t[N];

看起来变量很多             ,实际上我列举了我能想到的所有可能用到的变量      ,真正需要计算的不会是全部                    ,看题就好

二 指向立体星的存储 void add(int x,int y) { t[x].tnum++; t[y].fnum++; t[x].to[t[x].tnum]=y; t[y].from[t[y].fnum]=x; }

这是最普通的添加点             ,当然可以精简一下

void add(int x,int y) { t[x].to[++t[x].tnum]=y; t[y].from[++t[y].fnum]=x; }

如果存其他的东西,(边的编号                    ,权值等等)函数传值时传过来就好啦~

要注意的是这个结构体里数组的下标是结构体中的一个数据                    ,调用时要看清O-O!

三 实战应用

拓扑时它是最好用的,其他时候记得结合不同情况找最优的选择(๑•̀ㅂ•́)و✧

随机附赠一道例题(NOIP 2003 提高组第一题)

题目背景

人工神经网络(Artificial Neural Network)是一种新兴的具有自我学习能力的计算系统             ,在模式识别             、函数逼近及贷款风险评估等诸多领域有广泛的应用             。对神经网络的研究一直是当今的热门方向                    ,兰兰同学在自学了一本神经网络的入门书籍后       ,提出了一个简化模型             ,他希望你能帮助他用程序检验这个神经网络模型的实用性                    。

题目描述

在兰兰的模型中                    ,神经网络就是一张有向图       ,图中的节点称为神经元      ,而且两个神经元之间至多有一条边相连                    ,下图是一个神经元的例子:

公式中的 Wji(可能为负值)表示连接j号神经元和i号神经元的边的权值       。当C_i大于0时             ,该神经元处于兴奋状态      ,否则就处于平静状态      。当神经元处于兴奋状态时                    ,下一秒它会向其他神经元传送信号             ,信号的强度为Ci                    。

如此.在输入层神经元被激发之后,整个网络系统就在信息传输的推动下进行运作             。现在                    ,给定一个神经网络                    ,及当前输入层神经元的状态(Ci),要求你的程序运算出最后网络输出层的状态      。

输入格式

输入文件第一行是两个整数n(1≤n≤100)和p                    。接下来n行             ,每行2个整数                    ,第i+1行是神经元i最初状态和其阈值(Ui),非输入层的神经元开始时状态必然为0             。再下面P行       ,每行由2个整数i,j及1个整数Wij             ,表示连接神经元i,j的边权值为Wij

输出格式

输出文件包含若干行                    ,每行有2个整数       ,分别对应一个神经元的编号      ,及其最后的状态2个整数间以空格分隔。仅输出最后状态大于0的输出层神经元状态                    ,并且按照编号由小到大顺序输出                    。

若输出层的神经元最后状态均为0             ,则输出 NULL                    。

输入输出样例

输入

5 6

1 0

1 0

0 1

0 1

0 1

1 3 1

1 4 1

1 5 1

2 3 1

2 4 1

2 5 1

输出

3 1

4 1

5 1 #include<bits/stdc++.h> using namespace std; int n,p,quan[120][120]; struct ver { int c,u,ru,chu; int ch[90]; bool ask,isin=1; }s[120]; int main() { cin>>n>>p; for(int i=1;i<=n;i++) cin>>s[i].c>>s[i].u; int a,b; for(int i=1;i<=p;i++){ cin>>a>>b>>quan[a][b]; s[b].ru++; s[a].ch[++s[a].chu]=b; s[b].isin=0; } int ans=0; while(ans<n) for(int i=1;i<=n;i++){ if((s[i].ru==0&&!s[i].isin&&s[i].c-s[i].u<=0)||(s[i].ru==0&&s[i].c==0&&s[i].isin)){ ans++; for(int j=1;j<=s[i].chu;j++) s[s[i].ch[j]].ru--; continue; } if(s[i].ru==0&&s[i].ask==0){ ans++; s[i].ask=1; if(!s[i].isin) s[i].c-=s[i].u; for(int j=1;j<=s[i].chu;j++) s[s[i].ch[j]].ru--,s[s[i].ch[j]].c+=quan[i][s[i].ch[j]]*s[i].c; } } bool ok=0; for(int i=1;i<=n;i++) if(s[i].c>0&&s[i].chu==0) { cout<<i<<" "<<s[i].c<<endl; ok=1; } else continue; if(ok==0) cout<<"NULL"<<endl; return 0; }

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
uniapp我的页面设计(uniapp 中设置全局页面背景色) 主成分分析pca步骤(机器学习强基计划8-1:图解主成分分析PCA算法(附Python实现))