首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

好玩!C语言打印彩色字符,还能闪烁!

、各种背景色显示内容,还可以高亮、加粗、闪烁,非常好玩!...序列码格式 一串escape code的内容如下: 特殊字符\033 :通知终端切换到escape模式; 起始字符[:CSI内容的开始; CSI内容字符(见下表); CSI结束字符m:CSI内容的结束;...其中,CSI模式全称Command Sequence Introduction,当终端软件处于CSI模式时,终端软件读取之后的ASCII码作为CSI内容,直到读入CSI结束字符,代表不同字符的ASCII...代表背景颜色的特殊ASCII字符: 字符 颜色 40 黑色 41 红色 42 绿色 43 黄色 44 蓝色 45 紫色 46 深绿 47 白色 代表字体颜色的特殊字符: 字符 颜色 30 黑色 31...怎么样,在终端打印各种好玩的字符是不是非常简单~自己上手玩玩吧!

2.2K10

一个好玩的小游戏(纯C语言编写)

最近在看知乎是发现了一个这一个专栏 https://zhuanlan.zhihu.com/c2game 从中获取的许多知识,本文中的游戏也是从里面学到的,不过本人又自己加了一些功能。...这是一个类似于飞机大战的游戏,不过目前代码量比较小,所以看起来非常简陋游戏界面如下 更新日志,本人将原来的原来的代码有进一步的优化了一下,之前是只有一个非常小的战机现在更新后可以产生一个非常大的战机...(看起来也更有气势了~~)和敌人的战机,不过死亡的判定条件和边境的判断条件还没有做好,等下次再继续加油。...int position_x, position_y;//飞机的所在位置 int high, width;//地图的大小 int bullet_x, bullet_y;//子弹的位置 int...enemy_x, enemy_y;//敌人的位置 int map[MAX][MAX]; /*0表示空白,1表示战机*的区域,2表示敌人战机的位置。

75620
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    好好玩的螺旋算法No.69

    看到一个小伙伴分享这么一个东西,觉得蛮好玩的。先上图。我觉得蛮好玩的,就心心念念想着分享给你们也玩玩,顺便自己实现了一遍。 好,现在开始说是怎么玩的。 首先我观察到的一个科学的知识。...我们假设为 size 为 N 的我们叫做 N 阶螺旋矩阵。如果 N = 1。直接输出就行了。如果 N 为偶数,那么最大值在左下角。如果 N 为奇数,那么最大值在右上角。 那么怎么去形成这样一个圈圈呢?...可好玩了。 我们先在初始化的位置放一个小蕉,最大值 Math.pow(N,2) 。然后给它定义这么一些简单的一个指令,然后放小蕉自己去跑就行了。 如果N为偶数,那么第一步向右走。...向右走的时候如果撞到边界或其他数字了,向上走。否则继续向右走。 向上走的时候如果撞到边界或其他数字了,向左走。否则继续向上走。 向左走的时候如果撞到边界或其他数字了,向下走。否则继续向左走。...向下走的时候如果撞到边界或其他数字了,向右走。否则继续向下走。 每次走的时候都把当前的位置填上。 详细代码在这,常打小玩具手不生。 自己拿去玩玩吧~掰掰。欢迎交流。

    61290

    C语言BF算法

    相关文章路径:C语言求字符串的长度->C语言字符串的复制-> C语言的字符串的联接->C语言字符串的比较->C语言查找字符->C语言BF算法->C语言输出字符串->C语言输入字符串 C语言标准函数库中包括...作为练习,我们自己编写一个功能与之相同的函数。...函数原型 char* StrStr(const char *txt, const char *pat); 说明:txt 和 pat 分别为主串和子串的起始地址。...若查找成功,则函数值为子串在主串中首次出现的起始地址,否则函数值为NULL。 特别地,我们对C语言库函数strstr进行适当修改:若子串为空串,则没有意义,函数值规定为NULL。...printf("%d\n", p - m); } else { puts("NULL"); } return 0; } /* 你提交的代码将被嵌在这里

    6000

    C语言 排序算法_C语言中三大经典的排序算法

    4.1归并排序递归版本 4.2归并排序非递归版本 总结 ---- 前言 常见的排序算法如下: 一、插入排序 1.1直接插入排序 基本思想:把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中...: 元素集合越接近有序,直接插入排序算法的时间效率越高 时间复杂度:O(N^2) 空间复杂度:O(1),它是一种稳定的排序算法 稳定性:稳定 1.2希尔排序 希尔排序法又称缩小增量法。...(非递归) 主要通过数据结构栈来模拟实现类似于二叉树的前序遍历 如果有同学对C语言实现栈不熟悉可以点一下链接:C源实现数据结构栈 具体代码如下: typedef int STDataType; typedef...} } for (int i = 0;i <= right;i++)//打印 { printf("%d ", a[i]); } } 四 归并排序 归并排序(MERGE-SORT)是建立在归并操作上的一种有效的排序算法...,该算法是采用分治法(Divide andConquer)的一个非常典型的应用。

    2.8K20

    12个很好玩的C语言面试题,不来测试下嘛?

    12个C语言面试题,涉及指针、进程、运算、结构体、函数、内存,看看你能做出几个! 1.gets()函数 问:请找出下面代码里的问题: ?...答:上面代码里的问题在于函数gets()的使用, 这个函数从stdin接收一个字符串而不检查它所复制的缓存的容积, 这可能会导致缓存溢出。这里推荐使用标准函数fgets()代替。...2.strcpy()函数 问:下面是一个简单的密码保护功能,你能在不知道密码的情况下将其破解吗? ? 答:破解上述加密的关键在于利用攻破strcpy()函数的漏洞。...7.void*和C结构体 问:你能设计一个能接受任何类型的参数并返回interger(整数)结果的函数吗?...12.处理printf()的参数 问:下面代码会输出什么? ? 答:输出结果是: 110..40..60 这是因为C语言里函数的参数默认是从右往左处理的,输出时是从左往右。

    1.1K3130

    C语言单向链表的经典算法

    ,遍历原链表,将节点小的链表拿到新链表中尾插。...:思路:这里可以定义两个快慢指针,快指针 一次走两步,慢指针一次走两步(这里也要注意条件不能交换位置,两种情况都保证的情况下先满足小的,链表为偶数时fast最后一次会直接走到空,下一步就会报错) 代码:...1.关于这个算法题的小故事:著名的Josephus问题 据说著名犹太 Josephus有过以下的故事:在罗⻢⼈占领乔塔帕特后,39 个犹太⼈与 Josephus及他的朋友躲到⼀个洞中,39个犹太⼈决定宁愿死也不要被...历史学家 然⽽Josephus 和他的朋友并不想遵从,Josephus要他的朋友先假装遵从,他将朋友与⾃⼰安排在 第16个与第31个位置,于是逃过了这场死亡游戏。...2.思路:第一步创建环形链表(创建之前要先创建一个节点,可以用函数封装起来),第二步计数(又分为销毁链表和不销毁链表)下面我画了图以视频形式呈现 环形链表的约瑟夫问题

    6310

    C语言查找-----------BF算法&&KMP算法

    C语言实现这个查找的过程; #include #include #include //返回字串在主串里面的位置 //没有找到返回-1; int...3.KMP算法 我们想要了解KMP算法,就必须知道他和我们普通的暴力算法有什么不同之处,其实KMP算法是三个大佬发现的,KMP分别是这3个大佬名字的第一个字母(我们了解一下就可以了),他和普通算法的不同点就在于...,超详细,链接如下) 【完整版】终于有人讲清楚了KMP算法,Java语言C语言实现_哔哩哔哩_bilibili https://www.bilibili.com/video/BV1UL411E7M8/?...,第三个c回退到哪个下标,是以a开始,以他前面的b结尾的两个相同的子串,因为只有一个ab,所以我们next[2]=0;第四个字符,我们要找到以a开始,以c结尾的两个字符串,因为这里只有abc,所以next...,还有数组的越界访问,找不到和自己一样的字符就会不停的回退,直到相同才会停止,详情请根据视频自行学习; 【完整版】终于有人讲清楚了KMP算法,Java语言C语言实现_哔哩哔哩_bilibili https

    6910

    C语言算法-学习二

    也就是 算法(algorithm) 一个程序除了 算法 和 数据结构 这两个要素外,还应当采用 结构化程序设计方法 进行程序设计,并用某一种 计算机语言 表示。...什么是算法 算法是为了解决问题而执行的一系列步骤。 计算机的算法可以分为两大类别: 数值运算算法 数值运算的目的是求数值解。 非数值运算算法 非数值运算用于事务管理领域(图书检索,人事管理等等)。...一个算法应该包含有限的操作步骤,而不能是无限的 确定性。算法的每一个步骤都应当是确定的,而不是含糊的、模棱两可的 有零个或多个输入。输入是指在执行算法时需要从外界取得的必要信息 有一个或多个输出。...算法的目的是为了求解,“解”就是输出 有效性。算法中的每一个步骤都应当能有效地执行,并得到确定的结果 怎么表示一个算法 常用的方法有: 自然语言 流程图 NS图 伪代码 .........用C语言表示算法 while循环 #include int main() { int a,i; a = 1; i = 2; while(i <=

    2.7K30

    一个好玩的 Go 语言 REPL 工具

    简介 周末闲逛 GitHub 的时候发现一个很好玩的 Go 语言的 REPL(read-eval-print-loop)工具。本文和大家分享一下这个工具:gore。...其他命令的执行速度也不快 doc 命令的限制有点奇怪。为什么包不能加路径?go doc 是可以加路径的。也有可能我使用的姿势不对,有知道的可以指点一二 多行输入有点反直觉。...如果我没有输入完整的代码,它会一直等着我输入。可是我已经不想输入了。有一次我键入 type 命令时忘记加:了,就变成这样了: 当然,可以通过Ctrl + C终止输入,这个让我摸索了好一会儿。...我个人使用其他软件的经验是连续几个空行就可以终止了。这一点严格来说不算缺点,只是不符合我的习惯。 总结 总体来说 gore 是一个比较好玩的工具,期待项目发展壮大!...大家如果发现好玩、好用的 Go 语言库,欢迎到 Go 每日一库 GitHub 上提交 issue 参考 gore GitHub:github.com/x-motemen/gore Go 每日一库 GitHub

    90740

    蓝桥 算法训练 藏匿的刺客(C语言)

    资源限制 内存限制:256.0MB   C/C++时间限制:1.0s   Java时间限制:3.0s   Python时间限制:5.0s 问题描述   强大的kAc建立了强大的帝国,但人民深受其学霸及23...文化的压迫,于是勇敢的鹏决心反抗。   ...kAc帝国的派出的n个看守员都发现了这一问题,第i个人会告诉你在第li个草堆到第ri个草堆里面有人,要求你计算所有草堆中最少的人数,以商议应对。   ...样例输入 5 2 4 1 3 5 7 1 8 8 8 样例输出 3 数据规模和约定   30%的数据n<=10   70%的数据n<=100   100%的数据n<=1000   所有数字均在...,只要i-1的右端点>i的左端点的就另起一个 if (a[i][0] > x) { //标记vis[i]=1;若i-1的右端点的左端点就共用一个刺客 vis[i] = 1;

    7710

    一个c语言程序能实现几种算法_C语言实现算法

    摘要:本文主要是对 DOA(波达方向)估计中传统 MUSIC 算法及其改进算法作了简要 的介绍,主要包括了MUSIC算法,求根MUSIC算法,循环MUSIC算法,波束空间MUSIC算法,SMART MUSIC...各算法分析及性能介绍 2.1 MUSIC算法之前的DOA估计算法 DOA估计的传统方法主要基于波束形成和零陷引导的概念,并没有利用到接受信号矢量的模型或者是信号和噪声的统计模型。...2.3求根MUSIC算法: 2.3.1求根MUSIC算法原理 对于阵元间距为d的等距直线阵列,导引向量 的第m个元素可以表示为 则MUSIC谱函数可以写成: 其中 是矩阵C中第L条对角线的元素之和。...假定入射信号为窄带信号,波长为 ,则M维接受信号矢量可以表示为 其中 是阵列方向向量: 从向量 中抽出一个L维的子向量 ( ),有 当满足 时, 当满足 时, 可以证明,向量 的子向量的相关矩阵C满足...3.结论 本文从各种基于MUSIC算法的改进算法的原理入手,从理论角度分析了各算法的推导过程,并在每节最后给出了简要的性能分析。

    3.5K30

    PID控制算法的C语言实现

    位置型PID的C语言实现 上一节中已经抽象出了位置性PID和增量型PID的数学表达式,这一节,重点讲解C语言代码的实现过程,算法的C语言实现过程具有一般性,通过PID算法的C语言实现,可以以此类推,设计其它算法的...PID的数学公式请参见我的系列文《PID控制算法的C语言实现二》中的讲解。...实现过程仍然是分为定义变量、初始化变量、实现控制算法函数、算法测试四个部分,详细分类请参加《PID控制算法的C语言实现三》中的讲解,这里直接给出代码了。...个数据为: 五 积分分离的PID控制算法C语言实现 通过三、四两篇文章,基本上已经弄清楚了PID控制算法的最常规的表达方法。...其它部分的代码参见《PID控制算法的C语言实现三》中的讲解,不再赘述。

    3.6K30

    C语言实现洗牌算法

    这样随机50次取出的书就不会重复,这就是今天的主题:洗牌算法 洗牌算法 Fisher-Yates洗牌算法是由 Ronald A.Fisher和Frank Yates于1938年发明的,后来被Knuth在书中介绍...我们现在所使用的各种算法复杂度分析的符号,就是他发明的。 等概率:洗牌算法有些人也称等概率洗牌算法,其实发牌的过程和我们抽签一样的,大学概率论讲过抽签是等概率的,同样洗牌算法选中每个元素是等概率的。...n*n),空间复杂度为O(n) 算法思路: 在上面的介绍的发牌过程中, Knuth 和 Durstenfeld 在Fisher 等人的基础上对算法进行了改进,在原始数组上对数字进行交互,省去了额外O(n...该算法的基本思想和 Fisher 类似,每次从未处理的数据中随机取出一个数字,然后把该数字放在数组的尾部,即数组尾部存放的是已经处理过的数字。...int randX = randNumber/M;    int randY = randNumber%M;        swap(iX,iY,randX,randY); } 更多案例可以go公众号:C语言入门到精通

    3.1K2219

    浅析C语言贪心算法

    前言 贪心算法的定义: 贪心算法是指在对问题求解时,总是做出在当前看来是最好的选择。也就是说,不从整体最优上加以考虑,只做出在某种意义上的局部最优解。...贪心算法不是对所有问题都能得到整体最优解,关键是贪心策略的选择,选择的贪心策略必须具备无后效性,即某个状态以前的过程不会影响以后的状态,只与当前状态有关。...贪心算法和动态规划本质上是对子问题树的一种修剪,两种算法要求问题都具有的一个性质就是子问题最优性(组成最优解的每一个子问题的解,对于这个子问题本身肯定也是最优的)。...贪心算法的定义: 贪心算法是指在对问题求解时,总是做出在当前看来是最好的选择。也就是说,不从整体最优上加以考虑,只做出在某种意义上的局部最优解。...总结 这篇文章我简单介绍了贪心算法,真的只是简单介绍,大佬们可以划走了,但这篇文章对新手还是会有很多帮助的,希望这篇文章可以为广大算法新手们的深入学习打好基础。

    11010

    C语言银行家算法

    算法简介 银行家算法(Banker’s Algorithm)是一个避免死锁(Deadlock)的著名算法,是由艾兹格·迪杰斯特拉在1965年为T.H.E系统设计的一种避免死锁产生的算法。...算法目的 为了了解系统的资源分配情况,假定系统的任何一种资源在任意时刻只能被一个进程使用,任何进程已经占用的资源只能由进程自己释放,而不能由其他进程抢占,当进程申请的资源不能满足时,必须等待。...因此只要资源分配算法能保证进程的资源请求,且不出现循环等待,则系统不会出现死锁。 算法原理 在避免死锁的方法中,所施加的限制条件较弱,有可能获得令人满意的系统性能。...在该方法中把系统的状态分为安全状态和不安全状态,只要能使系统始终都处于安全状态,便可以避免发生死锁。 银行家算法的基本思想是分配资源之前,判断系统是否是安全的;若是,才分配。...它是最具有代表性的避免死锁的算法。 设进程cusneed提出请求REQUEST [i],则银行家算法按如下规则进行判断。

    4.4K20

    好玩的单机游戏_附近哪里好玩

    他说:“无人机的出现促使相关技术为许多工业领域带来革命性的颠覆。...Drone2Map for ArcGIS是Esri推出的一款支持多线程的64位桌面端的APP,它以ArcGIS平台为支撑,通过与Pix4D专业算法集成,提供了从无人机原始数据到高质量镶嵌正射产品、DSM...笔者拿到该软件后迫不及待的进行了测试,效果出乎意料,首先,软件界面出乎意料的好,打破了笔者对esri软件的传统印象,简洁、清爽是给人的第一印象。...通过以上的测试,可以发现Drone2map for ArcGIS他对数据处理的流程是非常简单(一键式处理)、非常自动化的,通过工程的建立——>选择模板——>输出成果,减少了许多专业的数据处理步骤,极高的加快了数据生成的作业进度...随着无人机技术的发展,GIS技术也在跟着主流IT技术的发展而发展,esri非常重视无人机技术,无人机行业的发展以及Drone2map for ArcGIS实用、易用、高效、低成本等特点,将在智慧城市中的各行各业的专业领域中有极大的潜力和发展

    1.7K20
    领券