#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <conio.h> //行宽度
#define ROW_LEN 38 //比特位域结构
typedef struct bits bits;
struct bits{ unsigned int c0 : ;
unsigned int c1 : ;
unsigned int c2 : ;
unsigned int c3 : ;
unsigned int c4 : ;
unsigned int c5 : ;
unsigned int c6 : ;
unsigned int c7 : ;
}; //行类型
typedef bits row[( ROW_LEN + ) / ]; //读取行中元胞
unsigned int get_cell( row rw, int x ){ unsigned int re = ; if( x < - || x > ROW_LEN ){ puts( "get_cell: 坐标错误." ); return re;
} if( - == x ){ x = ROW_LEN - ;
} if( ROW_LEN == x ){ x = ;
} switch( x % ){ case :{ re = rw[x / ].c0;
}break; case :{ re = rw[x / ].c1;
}break; case :{ re = rw[x / ].c2;
}break; case :{ re = rw[x / ].c3;
}break; case :{ re = rw[x / ].c4;
}break; case :{ re = rw[x / ].c5;
}break; case :{ re = rw[x / ].c6;
}break; case :{ re = rw[x / ].c7;
}break;
} return re;
} //修改行中元胞
void set_cell( row rw, int x, unsigned int v ){ if( x < - || x > ROW_LEN ){ puts( "set_cell: 坐标错误." ); return;
} if( - == x ){ x = ROW_LEN - ;
} if( ROW_LEN == x ){ x = ;
} v = v % ; switch( x % ){ case :{ rw[x / ].c0 = v;
}break; case :{ rw[x / ].c1 = v;
}break; case :{ rw[x / ].c2 = v;
}break; case :{ rw[x / ].c3 = v;
}break; case :{ rw[x / ].c4 = v;
}break; case :{ rw[x / ].c5 = v;
}break; case :{ rw[x / ].c6 = v;
}break; case :{ rw[x / ].c7 = v;
}break;
}
} //演化行中元胞
unsigned int evo_cell( row rw, int x, unsigned char tab ){ unsigned char num = ; if( x < || x > ROW_LEN - ){ puts( "evo_cell: 坐标错误." ); return ;
} num |= ( unsigned char )get_cell( rw, x - );
num <<= ;
num |= ( unsigned char )get_cell( rw, x );
num <<= ;
num |= ( unsigned char )get_cell( rw, x + ); return ( tab >> num ) & 0x01;
} //演化行到另外一个行
void evo_row( row rw1, row rw2, unsigned char tab ){ int x; for( x = ; x < ROW_LEN; x++ ){ set_cell( rw2, x, evo_cell( rw1, x, tab ) );
}
} //随机初始化行
void rand_row( row rw ){ int x; for( x = ; x < ROW_LEN; x++ ){ set_cell( rw, x, rand() % );
}
} //显示行
void display_row( row rw ){ int x; for( x = ; x < ROW_LEN; x++ ){ printf( "%s", get_cell( rw, x ) ? "▉" : " " );
} printf( "\n" );
} //规则选择,这里选择为规则30,随机产生等腰三角形
//这种自动机是一种随机数算法的根基
#define TYPE_ID 30 //主函数
int main( int argc, char * argv[] ){ row rw1, rw2; srand( ( unsigned int )time( NULL ) ); rand_row( rw1 ); while( ){ display_row( rw1 ); _getch(); evo_row( rw1, rw2, TYPE_ID ); display_row( rw2 ); _getch(); evo_row( rw2, rw1, TYPE_ID );
} return ;
}

运行效果:

沃尔夫勒姆自动机时空图输出 C语言实现的更多相关文章

  1. 【1024打卡】C++字符串的输出((c语言风格)

    c++字符串输出(c语言风格) 文章目录 c++字符串输出(c语言风格) 杂记 代码 杂记 今天程序设计竞赛白给了,果然还是太弱了,y总带带我TAT ┭┮﹏┭┮1024快乐 代码 c语言学习 #inc ...

  2. 贪吃蛇游戏(printf输出C语言版本)

    这一次我们应用printf输出实现一个经典的小游戏—贪吃蛇,主要难点是小蛇数据如何存储.如何实现转弯的效果.吃到食物后如何增加长度. 1 构造小蛇 首先,在画面中显示一条静止的小蛇.二维数组canva ...

  3. PAT 1006 换个格式输出 C语言

    让我们用字母B来表示“百”.字母S表示“十”,用“12...n”来表示个位数字n(<10),换个格式来输出任一个不超过3位的正整数.例如234应该被输出为BBSSS1234,因为它有2个“百”. ...

  4. Problem O: 逆序输出——C语言初学者百题大战之二十

    #include<stdio.h> int main() { int a,b,c,d,e,n; scanf("%d",&n); a=n/; b=n%/; c=n ...

  5. 输出C语言中 变量的类型

    使用gcc的警告信息间接知道变量的类型 #include <stdio.h> #include <stdlib.h> #include <stddef.h> #in ...

  6. Mathematica

    Mathematica是一款科学计算软件,很好地结合了数值和符号计算引擎.图形系统.编程语言.文本系统.和与其他应用程序的高级连接.很多功能在相应领域内处于世界领先地位,它也是使用最广泛的数学软件之一 ...

  7. 杂项-数学软件:Mathematica

    ylbtech-杂项-数学软件:Mathematica Mathematica是一款科学计算软件,很好地结合了数值和符号计算引擎.图形系统.编程语言.文本系统.和与其他应用程序的高级连接.很多功能在相 ...

  8. BKDR Hash 函数实现

    K&R一书中提出的BKDR Hash算法,这里给出C函数实现,实际用的时候分布比较好而且实现简单.唯一不明白的就是为什么选择131这种模式的数字作为种子,隐隐有沃尔夫勒姆31号自动机的似曾相识 ...

  9. Stephen Wolfram自述

    Stephen Wolfram自述   作者: 阮一峰 大家听说过Stephen Wolfram(斯蒂芬·沃尔夫勒姆)吗? 了解他的经历和成就吗? 我对他了解不多,但是读了下面这篇2005年的演讲,联 ...

随机推荐

  1. POJ 3080 Blue Jeans (字符串处理暴力枚举)

    Blue Jeans  Time Limit: 1000MS        Memory Limit: 65536K Total Submissions: 21078        Accepted: ...

  2. 一脸懵逼学习hadoop之HDFS的java客户端编写

    1:eclipse创建一个项目,然后导入对应的jar包: 鼠标右击项目,点击properties或者alt+enter快捷键--->java build path--->libraries ...

  3. 利用 Windows API Code Pack 修改音乐的 ID3 信息

    朋友由于抠门 SD 卡买小了,结果音乐太多放不下,又不舍得再买新卡,不得已决定重新转码,把音乐码率压低一点,牺牲点音质来换空间(用某些人的话说,反正不是搞音乐的,听不出差别)… 结果千千静听(百度音乐 ...

  4. 创建和使用动态链接库(转)vs2008 vs2010

    最近在用c++使用dll,找了好久,下面有个例子.我用的是vs2010,第二个验证过没有问题! vs2008http://wenku.baidu.com/view/e2f64a3b87c2402891 ...

  5. IOS内存约定-【ios】

    IOS中内存采用引用计数的方式,在释放内存编程时采用约定的方式,在这里不长篇大论具体内存的原理,只从实用角度出发记录下如何根据这些约定来释放内存. 具体约定为: 当你使用new.alloc.copy  ...

  6. python全栈开发day59-Django基础

    一.今日内容总结 1.HTTP协议: 请求:浏览器发给服务端的消息 格式: 请求方法 URL 协议版本\r\n k1: v1\r\n k2: v2\r\n \r\n 请求体(请求数据) 响应:服务端返 ...

  7. python---初始sqlite3

    ***sqllite不需要单独安装,python2.5以上自带的! ***官方中文文档:https://docs.python.org/2/library/sqlite3.html ***SQLite ...

  8. web项目部署以及放到ROOT目录下

    最近度过了一个国庆长假,好几天都没有写博客了! 发布这篇案例也是希望能帮助到像我一样的菜鸟o(* ̄︶ ̄*)o,百度上面的资料都不怎么全.也没有人说明注意事项.总是这篇说一点.那个人也说补一点,最后自己 ...

  9. Service Fabric SfDevCluster目录从默认的C盘移动

    管理员权限打开Powershell CD\ 回车 CD "C:\Program Files\Microsoft SDKs\Service Fabric\ClusterSetup" ...

  10. JavaScript项目重构到底有多少坑要填要踩

    看到代码的那一刻我惊呆了,就一个js文件,接近2000行的代码.这个还好,比这个行数多的我见的多了,这个还吓不到我.有哪些问题,一会再说. 因为从我接手的那一刻算起,几天后就要发新版本,我只要也只能调 ...