前言最近在回顾学习C语言时一些想做但没去做的练手小玩意,并且尽量不用一些便利的库函数以此来巩固基础制作思路首先建立一个六行七列的数组来存储日历计算获取今年今月今日然后通过蔡勒公式来获取本月的第一天和最后一天是星期几...,通过每月的第一天是星期几来确定第0行的循环从那列开始,从该行该列开始往后遍历到该月的最后一天,并建立一个相同大小的二维数组标记其位置。...= year / 100;int y = year - c * 100;int week = y + y / 4 + c / 4 - 2 * c + 26 * (month + 1) / 10 + day...- 1;while (week < 0)week += 7;return week=week%7-1;}获取当前日期的年月日首先使用了C语言的标准库函数time来获取当前时间,并且因为获取到的是从1970...= year / 100;int y = year - c * 100;int week = y + y / 4 + c / 4 - 2 * c + 26 * (month + 1) / 10 + day
任务:使用C完成控制台版万年历 从控制台输入年份和月份,然后显示该月日历。 使用分支和循环结构完成。...提示: 1.1900年1月1日是星期一 2.计算输入的月份的1月1日距离1900年1月1日有多少天 3.输入月份的1月1日是星期几 = 得到的总天数 % 7 4.然后根据下图可以看出,该月的1号是星期几...image.png 具体的实现步骤如下: 1、接收控制台输入的年份和月份 image.png 2 ....再计算输入的year年的1月1号到该年的month-1月底的总天数,比如:输入的是2016年8月,那么即计算2016年1月1日到2016年7月底的总天数。...image.png 1、然后计算输入的日期的1号是星期几(这里的间隔是\t来实现的) image.png 1、根据开头提示中的第4点,根据是星期几来打印几个\t。
“要成为绝世高手,并非一朝一夕,除非是天生武学奇才,但是这种人…万中无一” ——包租婆 这道理放在C语言学习上也一并受用。...在编程方面有着天赋异禀的人毕竟是少数,我们大多数人想要从C语言小白进阶到高手,需要经历的是日积月累的学习。 那么如何学习呢?当然是每天都练习一道C语言题目!! ? 作者 闫小林 白天搬砖,晚上做梦。...例42:C语言实现一个简单链表,它由3个学生数据的结点组成,要求输出各结点中的数据。 解题思路:读者在学习这道例题的时候,应该首先分析三个问题。 各个结点是怎么样构成链表的?...=10107;//学号赋值 c.score=85.0;//成绩赋值 head=&a;//将第1个结点的起始地址赋给头指针head a.next=&b;//将第2个结点的起始地址赋给第1个结点的...next成员 b.next=&c;//将第3个结点的起始地址赋给第2个结点的next成员 c.next=NULL;//第3个结点的next成员赋给null point=head; do
//操作菜单 int leap(int year); //判断某年是不是闰年 int days_month(int year,int month); //返回某月的天数...someday(int year,int month,int day); //计算某天是星期几 void search_month(int year,int month); //输出某月的日历...; getchar(); switch(i) { case 1: printf("请输入你要查询的年份...输出某年的日历 |\n",i); printf("\t\t| %d. ...输出某月的日历 |\n",i+1); printf("\t\t| %d.
大家好,又见面了,我是你们的朋友全栈君。...Windows 系统自带一个名为Shutdown.exe的程序,可以用于关机操作(位置在Windows\System32下),一般情况下Windows系统的关机都可以通过调用程序 shutdown.exe...来实现的,同时该程序也可以用于终止正在计划中的关机操作。
大家好,又见面了,我是你们的朋友全栈君。 1、方法,需要一个年份,一个月份。...33 } 34 } 2、MainTest测试类 1 public static void main(String[] args) { 2 // 万年历测试类...boolean isTrue = true; 5 while(isTrue) { 6 System.out.println("-------------万年历
#include<stdio.h> #include<stdlib.h> #include<time.h> int main(void) { int num...
扫雷游戏 扫雷游戏也是我们常见的小游戏,今天我们来简单实现一下这个小游戏(简陋版). 1.菜单 首先我们创建一个菜单,供玩家选择,菜单跟上一期的三子棋的菜单一样,这里就不多说了; void menu(...,这里创建11×11的数组是为了后面统计雷的个数,但实际玩家操作的是9×9的数组; InitBoard()函数将两个数组都初始化为对应的字符; DisplayBoard()函数是打印相应数组的扫雷界面的函数...; SetMine()函数是布置雷的函数; FindMine()函数是实现排雷的函数; void game() { //雷的信息存储 //1.布置雷的信息 char mine[ROWS]...i++) { //打印行号 printf("%d ", i); for (j = 1; j <= col; j++) { //打印字符 printf("%c...rand()函数生成随机数,而rand() % row是随机生成0-8的数,所以加1是生成1-9的数,刚好满足行数和列数的要求;我们布置雷的过程是,当这个随机生成的坐标位置是’ 0 ‘,就把当前位置改为
C语言是一种面向过程的语言,但是也可以用结构体和函数指针来模拟面向对象的特性,比如封装、继承和多态。下面我们来看一些具体的例子和应用。...封装是指把对象的属性和方法封装在一起,提供一个接口给外部调用,隐藏内部细节。在C语言中,我们可以用结构体来定义对象的属性,用函数指针来定义对象的方法,然后把它们放在一个结构体中,形成一个类。...在C语言中,我们可以用结构体嵌套来实现继承,即把父类作为子类的第一个成员。例如,我们可以定义一个学生类,继承自人类: 关注公众号:C语言中文社区,免费领取300G编程资料。...在C语言中,我们可以用函数指针来实现多态,即把不同类型的对象都转换为一个通用类型,然后调用它们共有的函数指针。...free(a1); free(d1); free(c1); return 0; } 以上就是C语言面向对象的一些例子。
冒泡排序(Bubble Sort)是一种计算机科学领域的较简单的排序算法。它的基本思想是通过重复遍历待排序的数据集,并依次比较相邻的两个数据项,如果它们的顺序错误则进行交换。...这个过程会持续重复直到所有相邻的数据项都已经交换完毕,此时说明该数据集已经排好序。...冒泡排序的名称来源于排序过程中,较小的数据项会被逐渐“浮”到数组顶部,这个过程就像碳酸饮料中二氧化碳气泡最终会上浮到顶部的现象一样。因此,这种排序算法因其这一特性而得名。...冒泡函数的核心思想就是:两两相邻的元素进行比较。...如下动图演示: 2.冒泡函数代码简单实现 void bubble_sort(int arr[], int sz)//参数接收数组元素个数 { int i = 0; for(i=0; i<sz-
学了C语言的小编闲来无事就想搞点事情做,发现可以用C语言做万年历,计算器,俄罗斯方块儿游戏之类的,就从万年历开始玩耍啦。 Step 1....输入所需的变量 输入月,年等变量是为了在后续循环时方便进行,变量也是C语言中比较常见的一种用法。 Step 3. 输入年份和月份 要查询某年某月某日是星期几就先要输入年份和月份。...小编给大家推荐一个学习氛围超好的地方,C/C++交流企鹅裙:【8.7.0+九.六.三+2.5.1】适合在校大学生,小白,想转行,想通过这个找工作的加入。...计算某年某月第一天的星期 当知道某年某月第一天的星期时就相当于大功告成了,接下来就是利用循环不断进行输出填满万年历。 Step 5....执行出来的结果就如图啦,有没有觉得C语言很神奇呢。 Step 6. 关闭工作区间 别以为程序执行OK就完了哦,最后还要关闭工作区间以防程序丢失,随时养成一个良好的习惯。
//蛇休眠的时间,休眠的时间越短,蛇的速度越快,休眠的时间越长,蛇的速度越慢 enum GAME_STATUS status;//游戏当前的状态 enum DIRECTION dir;//蛇当前走的方向...//蛇休眠的时间,休眠的时间越短,蛇的速度越快,休眠的时间越长,蛇的速度越慢 enum GAME_STATUS status;//游戏当前的状态 enum DIRECTION dir;//蛇当前走的方向...GAME_STATUS //游戏状态 { OK = 1,//正常运行 ESC,//按了ESC键退出,正常退出 KILL_BY_WALL,//撞墙 KILL_BY_SELF//撞到自身 }; 六、Snake.c...创建完蛇身后,将蛇的每一节打印在屏幕上。再设置当前游戏的状态,蛇移动的速度,默认的方向,初始成绩,蛇的状态,每个食物的分数。...while (cur) { del = cur; cur = cur->next; free(del); } free(ps->pFood); ps = NULL; } 八、Test.c
/* 基本数据结构的定义以及函数的声明 */ typedef int ElemType; typedef struct Node { ElemType elem; struct Node...createNode(ElemType x); void showList(ForwardList lst); void destroyList(ForwardList lst); // 创建元素为x的节点并插入到节点...where后面 // 若where为NULL, 则插入到链表lst的首部作为首节点 // 返回新节点的指针 NodePtr insertAfterNode(NodePtr where, ElemType...x, ForwardList lst); /* 链表相关函数的具体实现 */ NodePtr createNode(ElemType x) { NodePtr pNode =
猜字游戏 游戏的菜单: void menu() { printf("****************************************\n"); printf("****...1.play 0.exit ****\n"); printf("****************************************\n"); } 实现游戏的函数...函数为伪随机数生成器种子-----在srand()函数里面要放一个随机值,所以引用时间戳放进去 void game() { int ret = 0; int guess = 0; //拿时间戳来设置随机数的生成起点...//time_t time(time_t *timer) -时间戳的使用方法time函数(需引用time.h头文件)--time_t是它的类型,实质是long(长整型)--time_t *是指针类型...else { printf("恭喜你,猜对了\n"); break; } } } 主函数部分,srand 放在主函数,防止在game()函数里面过于频繁使用,以至于生成的随机值过于相近
c 语言中其实有专门的解析函数。..._POSIX_C_SOURCE || _DARWIN_C_SOURCE) */};其中 h_addr_list 是保存着 IP 地址,只不过这个地址不是我们常见的那种 192.168.1.1 之类的地址...,阻塞简单就是当我们的线程进行活动需要一些资源,如果当前资源不满足那么就有两种方式,一种是我等着,等条件满足了,我再进一步执行,一般是像加锁之类的,另一种就是条件不行,我直接报错,一分钟也不等了,这就是非阻塞...,这里我们的业务简单直接非阻塞。...select 就是最简单多路复用,就是将 sockfd 也就是一个个的 socket 或者文件描述符集中在一起处理,每个请求来了之后,我们去处理。
大家好,又见面了,我是你们的朋友全栈君。...你的意思还是不太明白 我这有个程序 你看看能不能帮我改一下 #include #include #define PI 3.14 int cxClient, cyClient ; float i, j
** ( ´´ิ∀´ิ` ) 还有两个小节就基本上简单的过了一遍C语言了,现在我们来讲诉什么是数组。** 字面意思:数组,数组的一个组?应该说一堆数值的一个集合?...我不知道大家的年龄段在于什么阶段,如果学过集合的话,大家应该知道数的集合吧?其实数组可以说是值的集合。 数组可以分成一位数组、二维数组、多维数组。...我在这里换一个说法吧,直接先说基础格式(语法),想必大家经过之前的学习应该也可以直接看语法了 我们先来看最简单的数组格式(语法): 例如:int a[10]; 这个就是一个数组名称是a数组是整数类型,...好了,我们之前的代码是不是用printf每一个输出一个a数组的值,如下: printf("a[0]的值是 :%d \n",a[0]); 我们的a[0]其中的0还需要自己打对吧?那么在这里就不用了。...是不是很简单呀? 持续更新… ( `)3’)▃▃▃▅▆▇▉
什么是递归 递归是学习C语⾔函数绕不开的⼀个话题,那什么是递归呢? 递归其实是⼀种解决问题的⽅法,在C语⾔中,递归就是函数⾃⼰调⽤⾃⼰。...我们写一个简单的递归 #include int main() { printf("hehe\n"); main();//main函数中⼜调⽤了main函数 return 0...; } 我们看到这个递归是每次都调用自己的main()函数没有限制条件所以一直打印hehe....二 递归怎么实现 和while等循环相似我们实现让递归停下的条件就是写一个限制条件,达到条件递归自动停止。...四 递归的特点 运用少量的代码来运算 思路清晰,化大为小 要有限制条件,每一次递归会逼近停止条件,要不会死循环 总结 其实递归程序会不断的展开,在展开的过程中,我们很容易就能发现,在递归的过程中会有重复计算
return 0; } 我们这节课的内容就是了解scanf的使用,我直接用上面的代码来讲解,这样大家比较易懂一点。...,在这里表示取得a的地址。...所以我们在这里使用了&a,取得a的地址,这样的话我们输入的值就能够存入a不变量了。 在这里要说明的是,在这里和之前一样,如果变量为浮点数变量,那么%d就要改为%f,大家这点都懂吧?...好了,我们再看下一句,下一句的意思就是输出a的值,因为我们刚刚改变过了,现在来看看这个值是否有所改变,结果如下: ? 我红色箭头标注的就是我输入的值,你们看看,是不是后面输出的时候就有所改变呢?...不会的可以在留言区留言,我看到了我会解答的~重点内容 持续更新…╰(`□′)╯
大家好,又见面了,我是你们的朋友全栈君。 简单选择排序 (Simple Selection Sort)也称作直接选择排序。 算法步骤: 1) 设待排序的记录存放在数组Data[1…n]中。...书上的例子: 时间复杂度 O( n 2 n^2 n2) 空间复杂度 O(1) 算法特点: 1 ) 就选择排序方法本身来讲,它是一种稳定的排序 方法,但图中例子所表现出来的现象是不稳定的,这是因为上述实现选择排序的算法采用...“交换记录”的策略所造成的,改变这个策略可以写出不产生“不稳定现象”的选择排序算法。...i].key); } void SelectSort(SqList &L)//简单选择排序 { int i,j,//利用两层循环排序所有关键字 k;//k为记录剩余关键字中最小的位置...} } int main() { SqList L; InitList(L);//初始化顺序表 CreateList(L);//创建顺序表 SelectSort(L);//简单选择排序
领取专属 10元无门槛券
手把手带您无忧上云