沃尔夫勒姆自动机时空图输出 C语言实现
#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语言实现的更多相关文章
- 【1024打卡】C++字符串的输出((c语言风格)
c++字符串输出(c语言风格) 文章目录 c++字符串输出(c语言风格) 杂记 代码 杂记 今天程序设计竞赛白给了,果然还是太弱了,y总带带我TAT ┭┮﹏┭┮1024快乐 代码 c语言学习 #inc ...
- 贪吃蛇游戏(printf输出C语言版本)
这一次我们应用printf输出实现一个经典的小游戏—贪吃蛇,主要难点是小蛇数据如何存储.如何实现转弯的效果.吃到食物后如何增加长度. 1 构造小蛇 首先,在画面中显示一条静止的小蛇.二维数组canva ...
- PAT 1006 换个格式输出 C语言
让我们用字母B来表示“百”.字母S表示“十”,用“12...n”来表示个位数字n(<10),换个格式来输出任一个不超过3位的正整数.例如234应该被输出为BBSSS1234,因为它有2个“百”. ...
- Problem O: 逆序输出——C语言初学者百题大战之二十
#include<stdio.h> int main() { int a,b,c,d,e,n; scanf("%d",&n); a=n/; b=n%/; c=n ...
- 输出C语言中 变量的类型
使用gcc的警告信息间接知道变量的类型 #include <stdio.h> #include <stdlib.h> #include <stddef.h> #in ...
- Mathematica
Mathematica是一款科学计算软件,很好地结合了数值和符号计算引擎.图形系统.编程语言.文本系统.和与其他应用程序的高级连接.很多功能在相应领域内处于世界领先地位,它也是使用最广泛的数学软件之一 ...
- 杂项-数学软件:Mathematica
ylbtech-杂项-数学软件:Mathematica Mathematica是一款科学计算软件,很好地结合了数值和符号计算引擎.图形系统.编程语言.文本系统.和与其他应用程序的高级连接.很多功能在相 ...
- BKDR Hash 函数实现
K&R一书中提出的BKDR Hash算法,这里给出C函数实现,实际用的时候分布比较好而且实现简单.唯一不明白的就是为什么选择131这种模式的数字作为种子,隐隐有沃尔夫勒姆31号自动机的似曾相识 ...
- Stephen Wolfram自述
Stephen Wolfram自述 作者: 阮一峰 大家听说过Stephen Wolfram(斯蒂芬·沃尔夫勒姆)吗? 了解他的经历和成就吗? 我对他了解不多,但是读了下面这篇2005年的演讲,联 ...
随机推荐
- 牛客寒假算法基础训练集中营4 E题 Applese 涂颜色
链接:https://ac.nowcoder.com/acm/contest/330/E 来源:牛客网 题目描述 精通程序设计的 Applese 叕写了一个游戏. 在这个游戏中,有一个 n 行 m 列 ...
- [转] ES6展开运算符
语法 用于函数调用 myFunction(...iterableObj); 用于数组字面量 [...iterableObj, 4, 5, 6] 函数传参 目前为止,我们都是使用Function.pro ...
- poshytip基本使用
js基本调用方法 $("#tips").poshytip({ content: $this.text(), alignTo: 'target', alignX: direction ...
- 用webstorm搭建vue项目
本文只针对新手. 首先要明白几个名词(概念). Node.js: Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境. Node.js 使用了一个事件驱动.非阻塞式 ...
- mySql中SUBSTRING_INDEX函数用法
SUBSTRING_INDEX(str,delim,count) 返回字符串 str 中在第 count 个出现的分隔符 delim 之前的子串.如果 count 是一个正数,返回从最后的(从左边开始 ...
- hive中使用union出现异常数据
select * from tbl where id=2 union select * from tbl where id =1 如果hive使用union这么查询的时候,我们会发现数据变乱了. 解决 ...
- HDU-1013的解题报告
题目来源:hdu-1013 题意:正整数的数字根是通过求整数的整数而求出的.如果结果值是一个位数,那么这个数字就是数字根.如果结果值包含两个或多个数字,则将这些数字相加并重复该过程.只要需要获得一个数 ...
- JAVA首次课堂测试总结
暑期生活已经结束,新的学期也已经开始,而暑期放假之前约定的JAVA首次课堂测试也如期的到来,本次测试真的可以学到和多东西,也有很多感想. 首先体会最深的就是系主任所说的软件工程不是那么好学的,真的需要 ...
- HDU-1247 Hat’s Words (暴力)【Trie树】
<题目链接> 题目大意: 给你一些单词,要求输出将该单词完全分成前.后两个单词之后,若这两个单词都在单词库中出现,则输出该单词. 解题分析: 将每个单词的每一位能够拆分的位置全部暴力枚举一 ...
- Elasticsearch 基于 URL 的搜索请求
背景 Elasticsearch 不像关系型数据库,没有简易的 SQL 用来查询数据,只能通过调用 RESTful API 实现查询.大体上查询分为两种,基于 URL 的和基于请求主体的.基于 URL ...