资源简介
c语言编写的scale-free network生成程序,可以自己设定初始有几个点,几条边,适合网络初学者
代码片段和文件信息
#include
#include
#include
//BA无标度网络
#define N 20000
typedef struct node
{
int name;
node* link;
int degree;
double probability;
};
int main(){
FILE* fp;
int ijkhx;
int m0m;
int D;//the sum of all the node degree
double count prosum;
fp = fopen(“BA-out.txt““w+“);
node *no *no1;
node *Node[N];//Node数组中元算关心的是节点的度,Node数组后面连接的只关心其与哪个节点相连(即每次不更新后面节点的度)
printf(“Please input m0 and m (m <= m0)!\n“);
scanf(“%d %d“&m0 &m);
sum = 0;
//网络初始化,初始节点互相连通
for (i = 0; i < m0; i++){
Node[i]=(node*)malloc(sizeof(node));
Node[i]->name = i+1; Node[i]->degree = m0-1; Node[i]->probability = (double)1/m0; Node[i]->link = NULL;
no = (node*)malloc(sizeof(node));
no = Node[i];
for (j = 1; j <= m0; j++)
if (j != i+1){
no1 = (node*)malloc(sizeof(node));
no1->name = j; no1->link = NULL; no1->degree = 0; no1->probability = 0;
no->link = no1;
no = no->link;
}
sum = sum + Node[i]->probability;
}
D = m0 * (m0 - 1);
//优先链接的增长
double random;
srand((unsigned)time(NULL));
for (i = m0; i < N; i++){
//新加入点的初始化(无论有无连边,都要新加入一个点)
Node[i] = (node*)malloc(sizeof(node));
Node[i]->name = i+1;
Node[i]->link = NULL;
Node[i]->degree = 0;
Node[i]->probability = 0;//先初始化为0,等到新加入的点全部算完,再一起重新计算概率
- 上一篇:高斯函数消元法c语言源代码,解矩阵用的
- 下一篇:计算机图形学画月亮C语言
相关资源
- Large Scale C++ Software Design
- FreeRTOS 官方指导 英文(Mastering_the_F
- FreeRTOS 官方 参考手册 英文
- stm32cubeIDE hul库freertos can中断收发,
- STM32F407:FreeRTOS+HAL库移植
- STM32F030C8T6-FreeRTOS (BUTTERFLY遥控-Free
- [野火®]《FreeRTOS 内核实现与应用开
- sip.js demo(freeswitch)
- STM32F030 freertos+串口空闲中断接收 例程
- FreeRTOS入门手册_中文
- freetype_CSharp_Library.rar
- OpenGL+C++太阳系实现.zip
- C-free 5.0 C/C++
- c free3_5---小巧简单方便的C/C++编译器
- Cfree5.0---好用的C语言编程软件
- C-Free 4.0 标准版
评论
共有 条评论