128:忆往昔,迎春来

2024-04-02 07:52
文章标签 128 迎春 忆往昔

本文主要是介绍128:忆往昔,迎春来,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

机缘

时间真的是过得好快啊,128,距离我的第一篇博客已经128天了,从大一上的冬天,到大一下的春夏,从一个初入大学的新人,到一个开始思考未来的新人。我开始不断更新博客,开始不断吸收知识,开始连续提交代码,一切开始步入正轨,积累知识,循序渐进。

我写博客主要是为了复盘知识,我一直感觉当能把大家讲懂了,这个知识就真真正正地属于我了。将自己每天所学的知识用文字来讲述出来,能很好地保持对知识的热情,不断的激发创造的激情。当然,还有一个原因是想为自己未来的简历加码,现在才大一,所有的知识积累要不断进行,学好技术,学好技术!!!

不登高山,不知天之高也,不临深溪,不知地之厚也。CSDN中的大佬好多啊,我也要一直加油呀。


收获

我感觉写博客给我带来的好处有很多:

首先就是从正式的第一篇博客开始到现在,我的博客内容编写能力进步了很多,我现在回看第一篇技术博客,无论是文章内容,还是结构设置,其实能明显感觉到稚嫩,而现在所写的博客才算是正式的入门。这个方面可以说是最明显的改变了。

其次是知识的梳理、总结能力,这个是毋庸置疑的,当你想写一篇博客,需要构思目录大纲,还需要细化细节内容,这方面对我提升了挺多的。当然还有鼓励,非常感谢支持我的粉丝朋友了,大家的支持让我能一直坚持下来。谢谢大家!!!

目前粉丝不算多,但我会不断的写下去,得到更多的认可,不辜负大家的支持。


日常

我将学习与写博客给平衡下来是有一段适应时间的,起初,总是说学习完之后没时间写博客,只是偶尔感觉有必要写的时候才写,后来我意识到就是懒,一直待在自己的舒适圈,所以我现在是学习到一节知识点,就写一篇博客,我感觉复盘一下是非常有必要的。

如今我也是大一的下学期,日常也就是学习-->敲代码-->上传Gitee-->写博客,大一毕竟主要是来学技术的。任尔东西南北风,我自岿然不动。


成就

我敲过的最长的程序,就是扫雷游戏了,其实也是跟着老师敲的,但敲出来之后是很有成就感的。

一、游戏逻辑部分: 

#define _CRT_SECURE_NO_WARNINGS 1
//主函数:测试逻辑
#include <stdio.h>
#include "game.h"
//菜单
void menu()
{printf("********************\n");printf("****** 1.play ******\n"); printf("****** 0.exit ******\n"); printf("********************\n");
}
//game完成扫雷游戏
void game()
{char mine[ROWS][COLS] = { 0 }; //棋盘mine初始化为字符‘0’char show[ROWS][COLS] = { 0 }; //棋盘show初始化为字符‘*’//初始化棋盘Initboard(mine, ROWS, COLS, '0');Initboard(show, ROWS, COLS, '*');//打印棋盘//Displayboard(mine, ROW, COL);Displayboard(show, ROW, COL);//布置雷SetMine(mine, ROW, COL);//Displayboard(mine, ROW, COL);//排查雷FindMine(mine, show, ROW, COL);}
//游戏运行逻辑
void text()
{srand((unsigned int)time(NULL));int input = 0;  //菜单选项do{menu();printf("请选择:");//1,0,其它scanf("%d", &input);switch (input){case 1:game();  //进入游戏break;case 0:printf("退出游戏\n");break;default :printf("选择错误,请重新选择\n");break;}} while (input);
}
int main()
{text();return 0;
}

二、函数部分

#define _CRT_SECURE_NO_WARNINGS 1
#include "game.h"
//初始化棋盘
void Initboard(char arr[ROWS][COLS], int rows, int cols, char set)
{for (int i = 0; i < rows; i++){for (int j = 0; j < cols; j++){arr[i][j] = set;}}
}
//打印棋盘
void Displayboard(char arr[ROWS][COLS], int row, int col)
{printf("------扫雷游戏-----\n");for (int i = 0; i <= col; i++){printf("%d ",i); //打印行号}printf("\n");for (int i = 1; i <= row; i++){	printf("%d ",i); //打印列号for (int j = 1; j <= col; j++){printf("%c ", arr[i][j]);//错误:要用%c输出(字符)}printf("\n");}
}//布置雷
//生成随机的坐标 在9*9的棋盘内布置
void SetMine(char arr[ROWS][COLS], int row, int col)
{int count = EASY_COUNT;//雷的个数while (count){int x = rand() % row + 1;int y = rand() % col + 1;if (arr[x][y] == '0'){arr[x][y] = '1';count--;}}
}//排查雷
int GetMineCount(char mine[ROWS][COLS], int x, int y)
{return (mine[x-1][y]+mine[x-1][y-1]+ mine[x - 1][y+1] + mine[x][y-1] + mine[x][y+1] + mine[x+1][y] + mine[x+1][y-1] + mine[x+1][y+1] - 8*'0');
}
void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col)
{int x = 0;int y = 0;int win = 0;while(win < row*col-EASY_COUNT){ printf("请输入排查的坐标x y:\n");scanf("%d %d", &x, &y);if (x > 0 && x <= row && y > 0 && y <= col){if (mine[x][y] == '1'){printf("很遗憾,你被炸死了\n");Displayboard(mine, ROW, COL);break;}else{//统计该坐标周围雷的个数int count = GetMineCount(mine, x, y);show[x][y] = count + '0';Displayboard(show, ROW, COL);win++;}}elseprintf("坐标非法,请重新输入\n");}if (win == row * col - EASY_COUNT){printf("恭喜你,排雷成功!!!");Displayboard(mine, ROW, COL);}
}

三、头文件部分

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#define ROW 9 //行为9
#define COL 9 //列为9#define ROWS ROW+2
#define COLS COL+2#define EASY_COUNT 10 //设置雷的个数为10//声明函数//初始化棋盘的函数
void Initboard(char arr[ROWS][COLS], int rows, int cols, char set);//打印棋盘
void Displayboard(char arr[ROWS][COLS], int row, int col);//布置雷
void SetMine(char arr[ROWS][COLS], int row, int col);//排查雷
void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col);

 将一大段代码分为了三个逻辑组成部分,第一次写的时候感觉非常神奇。

 


憧憬

希望技术越来越好,博客和Gitee能一直坚持写下去!!!

读书不觉已春深,一寸光阴一寸金 。加油呀。

这篇关于128:忆往昔,迎春来的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/869407

相关文章

Leetcode面试经典150题-128.最长连续序列-递归版本另解

之前写过一篇这个题的,但是可能代码比较复杂,这回来个简洁版的,这个是递归版本 可以看看之前的版本,两个版本面试用哪个都保过 解法都在代码里,不懂就留言或者私信 class Solution {/**对于之前的解法,我现在提供一共更优的解,但是这种可能会比较难懂一些(思想方面)代码其实是很简洁的,总体思想如下:不需要排序直接把所有数放入map,map的key是当前数字,value是当前数开始的

[LeetCode] 128. Longest Consecutive Sequence

题:https://leetcode.com/problems/longest-consecutive-sequence/description/ 题目 Given an unsorted array of integers, find the length of the longest consecutive elements sequence. Your algorithm should

Oracle - ORA-01652: unable to extend temp segment by 128 in tablespace TEMP

一、原因     意思是指TEMP表空间无法自动扩展TEMP段。这种问题一般有两种原因:一是临时表空间空间太小,二是不能自动扩展。 二、分析     查看TEMP表空间的数据文件个数,当前大小,是否自动扩展 SQL> SELECT TABLESPACE_NAME, FILE_NAME, BYTES/1024/1024 "CURR_SIZE(MB)", MAXBYTES/1024/102

解决UnicodeDecodeError: ‘ascii’ codec can’t decode byte 0xe5 in position 108: ordinal not in range(128

1.问题描述:一个在Django框架下使用Python编写的定时更新项目,在Windows系统下测试无误,在Linux系统下测试,报如下错误: ascii codec can't decode byte 0xe8 in position 0:ordinal not in range(128) 2.原因分析:字符问题。在Windows系统转Linux系统时,字符问题很容易出现。 3.解决办

SK Hynix明年将开发基于96/128 GB DDR5的CXL 2.0内存解决方案

SK Hynix 正致力于为人工智能领域开发基于 DDR5 的 CXL 2.0 内存解决方案,尤其是针对"内存饥渴型"LLM。CXL 指的是 Compute Express Link,这是一种互联技术,可以在 CPU 和 GPU 之间实现更快的数据传输,但在人工智能领域,它实际上是 CPU 和加速器之间的数据传输。 与传统的 PCIe 接口相比,CXL 的优势在于它能让 GPU 直接访问系统内

为什么在java中(byte)128输出是-128?

因为java中的自动转型,因此System.out.println((byte)128) 输出为-128。 在java中默认整型是int类型,int类型是4字节,32位。而byte类型是1字节,8位 而java中的二进制都是采用补码形式存储:⑴一个数为正,则它的原码、反码、补码相同⑵一个数为负,则符号位为1,其余各位是对原码取反,然后整个数加1 就int类型的128而言,: 原码为:000

UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-3: ordinal not in range(128)

问题背景 在python2中安装了labelme,可以正常运行,然后又再python3中安装了labelme。后来python2中的labelme不能运行,python3中的labelme可以运行。 具体问题 UnicodeEncodeError: ‘ascii’ codec can’t encode characters in position 0-3: ordinal not in ra

数学建模学习(128):使用Python结合CILOS与熵法的多准则决策权重确定

本文介绍方法为:结合CILOS与熵法的多准则决策权重,请理解为主,代码可以当作模板使用。 文章目录 1 引言2 问题背景2.1. 熵法 (Entropy Method)2.2 准则影响损失法 (CILOS Method)2.3 Python代码实现2.4 结果的决策指导意义 2.4 结论 参考文献 1 引言 多准则决策(Multi-Criteria Decision-M

c#实现生成AES加密的密钥key(密钥长度128位,也就是32个字符)对标Java中的AES加密(SHA1PRNG+Hex.encodeHexString)

最近在做某省份的一个健康云平台检验结果互认,我们的系统用的是C#,里面要求生成一个AES加密的密钥key(密钥长度128位,也就是32个字符),后面要用这个密钥key完成一系列加密操作,给的实例只有Java版本的获取该密钥的方法,在网上找了参考资料,整理出来了C#的对应实现,下面先看实例Java的代码实现和结果: import javax.crypto.Cipher;import javax.

哈希表的查找、插入及删除——217、633、349、128、202、500,290、532、205(五简四中)

217. 存在重复元素(简单) 给你一个整数数组 nums 。如果任一值在数组中出现 至少两次 ,返回 true ;如果数组中每个元素互不相同,返回 false 。 解法一、哈希 无则加入,有则代表重复,返回true 之后发现hs.add本身在存在时就会返回false,所以其实一次判断就好 class Solution {public boolean containsDupli