自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(49)
  • 资源 (1)
  • 收藏
  • 关注

原创 基于C语言的小游戏合集

小游戏之推箱子#include<stdio.h>#include<stdlib.h>#include<getch.h>int main(int argc,const char*argv[]){ int cut=0; int a[8][8]={ {0,0,3,3,3,3,0,0}, {0,0,3,5,5,3,0,0}, {0,0,3,0,5,3,0,0},

2020-09-22 10:04:05 48308 21

原创 网络聊天室 C语言

server.c 服务端#include<stdio.h>#include<stdlib.h>#include<string.h>#include<unistd.h>#include<sys/socket.h>#include<netinet/in.h>#include<pthread.h>#include<arpa/inet.h>#define MAX_BUF 50#define NAME

2020-09-07 11:40:20 360

原创 牛客网错题整理(持续更新中)

关于归并排序叙述正确的是( )A 归并排序使用了分治策略的思想B 归并排序使用了贪心策略的思想C 子序列的长度一定相等D 归并排序是稳定的正确答案:A D个数约为 50k 的数列需要从小到大排序, 数列特征是基本逆序 (多数数字从大到小,个别乱序) ,以下哪种排序算法在事先不了解数列特征的情况下性能大概率最优(不考虑空间限制)___.正确答案: EA冒泡排序B改进冒泡排序C选择排序D快速排序E堆排序F插入排序于以下说法,错误的是________。正确答案: CADi

2020-08-24 15:51:01 787 2

原创 学生管理系统小项目用C语言实现(部分功能可能不是很完善)

学生信息管理系统最近做了一个学生管理系统,大部分功能都还可以实现,若有可应该进修改的地方,请多多指教!可实现以下功能学生:姓名 性别 学号 密码 语文 数学 英语1、第一次登录强制修改密码。2、查询成绩3、修改密码4、查看个人信息5、三次密码错误锁定帐号,由教师解锁教师:姓名 性别 工号 密码1、第一次登录强制修改密码。2、添加学生(学生的学号自动生成)单个添加批量导入3、删除学生输入两人次学号确定删除的学生要记录保存在已退学的文件中4、查找学生按姓名查找按学号查找

2020-08-03 10:14:46 1857 2

原创 实习日记:logstash和grok的使用

logstash是一个数据分析软件,主要目的是分析log日志。整一套软件可以当作一个MVC模型,logstash是controller层,Elasticsearch是一个model层,kibana是view层。在这里插入图片描述首先将数据传给logstash,它将数据进行过滤和格式化(转成JSON格式),然后传给Elasticsearch进行存储、建搜索的索引,kibana提供前端的页面再进行搜索和图表可视化,它是调用Elasticsearch的接口返回的数据进行可视化。logstash和Elastic

2020-11-24 16:54:25 1066

原创 实习日记:初步学习elk

一. ELK是什么?ELK 是elastic公司提供的一套完整的日志收集以及展示的解决方案,是三个产品的首字母缩写,分别是ElasticSearch、Logstash 和 Kibana。ElasticSearch简称ES,它是一个实时的分布式搜索和分析引擎,它可以用于全文搜索,结构化搜索以及分析。它是一个建立在全文搜索引擎Apache Lucene 基础上的搜索引擎,使用 Java 语言编写。Logstash是一个具有实时传输能力的数据收集引擎,用来进行数据收集(如:读取文本文件)、解析,并将数

2020-11-20 15:42:01 1081

原创 Linux下Mysql的安装

1、确保ubuntu系统的网络畅通在ubuntu系统关机状态下​ 方案一、设置-》网络-》连接方式-》网络地址转换(NAT)​ 方案二、设置-》网络-》连接方式-》桥接 选择正确的网卡2、更新软件源​ sudo apt-get update3、安装MySQL数据库软件​ sudo apt-get install mysql-server 安装MySQL数据库管理软件​ sudo apt-get install mysql-client 安装MySQL数据库客户端,用户访问数据库​ s

2020-10-11 10:39:21 1064

原创 标准C++语言学习笔记1

一、C++介绍由本贾尼·斯特劳斯特卢普 于1979年4月份至1979年10月份开发一种语言,当时称为“C with Classes”(带类的C),后来演化为C++。C与C++区别:1、C++完全兼容C语言的所有内容。2、支持面向对象的编程思想(抽象、封装、继承、多态)。3、支持运算符、函数重载。4、支持泛型编程、模板。5、支持异常处理。6、类型检查严格。二、第一个C++程序1、文件扩展名:.cpp .cc .C .cxx2、编译器:g++ 大多数的Linux系统需要额外安装。

2020-09-24 15:30:42 175

原创 Linux环境编程——TCP和UDP

一、套接字基本特点:socket是一种接口技术,被抽象成一个文件操作,可以让进程之间通信,也可以让不同计算机的进程通信(网络)。int socket(int domain, int type, int protocol);功能:创建套接字domain: AF_UNIX/AF_LOCAL 本地通信,进程间通信 AF_INET 基于IPv4地址通信 AF_INET6 基于IPv6地址通信type: SOCK_STREAM 数据流协议 SOCK_DGRAM 数据

2020-09-11 16:17:20 126

原创 Linux环境编程———进程间通信

基本概念:什么是进程间通信:是指两个或多个进程之间交互数据的过程,因为进程之间是相互独立,为了协同工作必须交互数据。进程间通信的分类:简单的进程间通信:信号、文件、环境变量、命令行参数。传统的进程间通信:管道文件(有名管道、匿名管道)XSI进程间通信:共享内存、消息队列、信号量。网络进程间通信:套接字传统进程间通-管道管道是UNIX系统中最古老的进程间通信方式,古老就意味着所有系统都支持,早期的管道都是半双工,现在有些系统的管道是全双工(但要假定系统仅支持半双工)。管道是一种特殊的文件,它

2020-09-08 11:25:36 95

原创 面向对象的基本特征

封装封装最好理解了。封装是面向对象的特征之一,是对象和类概念的主要特性。封装,也就是把客观事物封装成抽象的类,并且类可以把自己的数据和方法只让可信的类或者对象操作,对不可信的进行信息隐藏。继承面向对象编程 (OOP) 语言的一个主要功能就是“继承”。继承是指这样一种能力:它可以使用现有类的所有功能,并在无需重新编写原来的类的情况下对这些功能进行扩展。通过继承创建的新类称为“子类”或“派生类”。被继承的类称为“基类”、“父类”或“超类”。继承的过程,就是从一般到特殊的过程。要实现继承,可以通过

2020-09-05 10:30:28 105

原创 PAT乙级1022

1022 D进制的A+B (20分)输入两个非负 10 进制整数 A 和 B (≤2​的30次方-1),输出 A+B 的 D (1<D≤10)进制数。输入格式:输入在一行中依次给出 3 个整数 A、B 和 D。输出格式:输出 A+B 的 D 进制数。#include<stdio.h>int main(){ int number_a=0,number_b=0,number_c=0,sum=0,count=0; int p[100]={0}; scanf

2020-08-28 11:33:33 166

原创 PAT乙级1021

1021 个位数统计 (15分)请编写程序统计每种不同的个位数字出现的次数。例如:给定 N=100311,则有 2 个 0,3 个 1,和 1 个 3。输入格式:每个输入包含 1 个测试用例,即一个不超过 1000 位的正整数 N。输出格式:对 N 中每一种不同的个位数字,以 D:M 的格式在一行中输出该位数字 D 及其在 N 中出现的次数 M。要求按 D 的升序输出。#include<stdio.h>int main(){ char n[1001]={0}; in

2020-08-28 11:32:16 88

原创 PAT乙级1020

1020 月饼 (25分)月饼是中国人在中秋佳节时吃的一种传统食品,不同地区有许多不同风味的月饼。现给定所有种类月饼的库存量、总售价、以及市场的最大需求量,请你计算可以获得的最大收益是多少。注意:销售时允许取出一部分库存。样例给出的情形是这样的:假如我们有 3 种月饼,其库存量分别为 18、15、10 万吨,总售价分别为 75、72、45 亿元。如果市场的最大需求量只有 20 万吨,那么我们最大收益策略应该是卖出全部 15 万吨第 2 种月饼、以及 5 万吨第 3 种月饼,获得 72 + 45/2 =

2020-08-28 11:29:25 93

原创 PAT乙级1019

1019 数字黑洞 (20分)给定任一个各位数字不完全相同的 4 位正整数,如果我们先把 4 个数字按非递增排序,再按非递减排序,然后用第 1 个数字减第 2 个数字,将得到一个新的数字。一直重复这样做,我们很快会停在有“数字黑洞”之称的 6174,这个神奇的数字也叫 Kaprekar 常数。例如,我们从6767开始,将得到7766 - 6677 = 10899810 - 0189 = 96219621 - 1269 = 83528532 - 2358 = 61747641 - 1467 =

2020-08-26 10:04:31 706 1

原创 PAT乙级1018

1018 锤子剪刀布 (20分)大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势。现给出两人的交锋记录,请统计双方的胜、平、负次数,并且给出双方分别出什么手势的胜算最大。#include<stdio.h>int main(){ int n=0; scanf("%d",&n); char c1,c2; int a_wj=0,a_wc=0,a_wb=0,b_wj=0,b_wc=0,b_wb=0,aw=0,bw=0,pj=0; for(i

2020-08-26 10:03:07 821 1

原创 PAT乙级1017

1017 A除以B (20分)本题要求计算 A/B,其中 A 是不超过 1000 位的正整数,B 是 1 位正整数。你需要输出商数 Q 和余数 R,使得 A=B×Q+R 成立。输入格式:输入在一行中依次给出 A 和 B,中间以 1 空格分隔。输出格式:在一行中依次输出 Q 和 R,中间以 1 空格分隔。#include<stdio.h>#include<string.h>int main(){ char a[1001]={0},b[1001]={0};

2020-08-26 10:02:00 794

原创 PAT乙级1016

1016 部分A+B (15分)正整数 A 的“DA(为 1 位整数)部分”定义为由 A 中所有 DA组成的新整数 PA。例如:给定 A=3862767,DA=6,则 A 的“6 部分”PA是 66,因为 A 中有 2 个 6。现给定 A、DA、B、DB​​ ,请编写程序计算 PA+PB。输入格式:输入在一行中依次给出 A、DA、B、DB,中间以空格分隔,其0<A,B<10的10次​​ 。输出格式:在一行中输出 PA+PB的值。#include<stdio.h>#in

2020-08-26 09:59:53 149

原创 PAT乙级1015

1015 德才论 (25分)宋代史学家司马光在《资治通鉴》中有一段著名的“德才论”:“是故才德全尽谓之圣人,才德兼亡谓之愚人,德胜才谓之君子,才胜德谓之小人。凡取人之术,苟不得圣人,君子而与之,与其得小人,不若得愚人。”现给出一批考生的德才分数,请根据司马光的理论给出录取排名。输入格式:输入第一行给出 3 个正整数,分别为:N(≤100000),即考生总数;L(≥60),为录取最低分数线,即德分和才分均不低于 L 的考生才有资格被考虑录取;H(<100),为优先录取线——德分和才分均不低于此线

2020-08-26 09:55:02 140 1

原创 PAT乙级1014

1014 福尔摩斯的约会 (20分)大侦探福尔摩斯接到一张奇怪的字条:我们约会吧! 3485djDkxh4hhGE 2984akDfkkkkggEdsb s&hgsfdk d&Hyscvnm。大侦探很快就明白了,字条上奇怪的乱码实际上就是约会的时间星期四 14:04,因为前面两字符串中第 1 对相同的大写英文字母(大小写有区分)是第 4 个字母 D,代表星期四;第 2 对相同的字符是 E ,那是第 5 个英文字母,代表一天里的第 14 个钟头(于是一天的 0 点到 23 点由数字 0 到

2020-08-26 09:53:46 134

原创 PAT乙级1013

1013 数素数 (20分)令 P​i表示第 i 个素数。现任给两个正整数 M≤N≤10000,请输出 PM到 PN的所有素数。输入格式:输入在一行中给出 M 和 N,其间以空格分隔。输出格式:输出从 P​M到 PN的所有素数,每 10 个数字占 1 行,其间以空格分隔,但行末不得有多余空格。#include <stdio.h>#include <math.h>int IsPrime(int t);int main(){ int m,n,i,count

2020-08-26 09:42:07 144 1

原创 PAT乙级1012

1012 数字分类 (20分)给定一系列正整数,请按要求对数字进行分类,并输出以下 5 个数字:A1= 能被 5 整除的数字中所有偶数的和;A​2= 将被 5 除后余 1 的数字按给出顺序进行交错求和,即计算 n1−n2+n3−n​4⋯;A​3= 被 5 除后余 2 的数字的个数;A​4= 被 5 除后余 3 的数字的平均数,精确到小数点后 1 位;A5= 被 5 除后余 4 的数字中最大数字。输入格式:每个输入包含 1 个测试用例。每个测试用例先给出一个不超过 1000 的正整数 N,随后给

2020-08-26 09:33:25 83

原创 Linux环境编程——进程相关

进程基本概念:1、进程与程序程序就是存储在磁盘上的可执行文件,程序被加载到内存中开始运行叫进程。一个程序可以被多次加载生成多个进程,进程就是处于活动状态的计算机程序。2、进程的分类进程一般分为三种类型:交互进程、批处理进程、守护进程。守护进程一般都处于活跃状态,运行在后台,由于系统在开机时通过启动脚本自动创建的。3、查看进程简单形式:ps 显示当前用户有控制终端的进程信息。列表形式:ps auxw 显示进程详细信息a 所有用户的有控制终端的进程x 无终端控制的进程u 显示进程的详细信息

2020-08-26 09:09:00 102 2

原创 PAT乙级1011

1011 A+B 和 C (15分)#include <stdio.h>int main(){ long int s[10][3]; int n = 0; scanf("%d", &n); for (int i = 0; i < n; i++) { for (int j = 0; j < 3; j++) { scanf("%ld",&s[i][j] ); } } for (int x = 0; x < n; x ++ ) {

2020-08-25 16:00:38 125

原创 PAT乙级1010

1010 一元多项式求导 (25分)#include <stdio.h>int eqt[100];int main() { int i = 0, k; //输入数值,k中存放的数值的个数 do { scanf("%d %d", &eqt[i], &eqt[i + 1]); i += 2; } while (eqt[i - 1] != 0); k = i; //进行求导计算 for (i = 0; i < k; i++) { if (i % 2

2020-08-25 15:57:30 71

原创 PAT乙级1009

1009 说反话 (20分)给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。输入格式:测试输入包含一个测试用例,在一行内给出总长度不超过 80 的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用 1 个空格分开,输入保证句子末尾没有多余的空格。#include<stdio.h>#include<string.h>int main(){ int n=0,m=0; char a[100],b[

2020-08-25 15:56:26 67

原创 PAT乙级1008

1008 数组元素循环右移问题 (20)一个数组A中存有N(>0)个整数,在不允许使用另外数组的前提下,将每个整数循环向右移M(≥0)个位置,即将A中的数据由(A​0 A1 ⋯AN−1)变换为(A(​N−M)⋯(AN−1) A0 A1⋯AN−M−1)(最后M个数循环移至最前面的M个位置)。如果需要考虑程序移动数据的次数尽量少,要如何设计移动的方法?输入格式:每个输入包含一个测试用例,第1行输入N(1≤N≤100)和M(≥0);第2行输入N个整数,之间用空格分隔。输出格式:在一行中输出循环右移

2020-08-25 15:55:31 112

原创 PAT乙级1007

1007 素数对猜想 (20分)让我们定义d​n为:dn=p(n+1)−pn,其中pi是第i个素数。显然有d1=1,且对于n>1有dn是偶数。“素数对猜想”认为“存在无穷多对相邻且差为2的素数”。现给定任意正整数N(<100000​​ ),请计算不超过N的满足猜想的素数对的个数。输入格式:输入在一行给出正整数N。输出格式:在一行中输出不超过N的满足猜想的素数对的个数。#include<stdio.h>#include<math.h>int is_sus

2020-08-25 15:54:20 72

原创 PAT乙级1006

1006 换个格式输出整数 (15分)让我们用字母 B 来表示“百”、字母 S 表示“十”,用 12…n 来表示不为零的个位数字 n(<10),换个格式来输出任一个不超过 3 位的正整数。例如 234 应该被输出为 BBSSS1234,因为它有 2 个“百”、3 个“十”、以及个位的 4。#include<stdio.h> int main(){ int num,i; int b=0,s=0,g=0; scanf("%d",&num); if(num/100

2020-08-25 15:52:44 67

原创 PAT乙级1005

1005 继续(3n+1)猜想 (25分)卡拉兹(Callatz)猜想已经在1001中给出了描述。在这个题目里,情况稍微有些复杂。当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推过程中遇到的每一个数。例如对 n=3 进行验证的时候,我们需要计算 3、5、8、4、2、1,则当我们对 n=5、8、4、2 进行验证的时候,就可以直接判定卡拉兹猜想的真伪,而不需要重复计算,因为这 4 个数已经在验证3的时候遇到过了,我们称 5、8、4、2 是被 3“覆盖”的数。我们称一个数列中的某个数 n 为“关键

2020-08-25 15:51:02 75

原创 PAT乙级1004

1004 成绩排名 (20分)读入 n(>0)名学生的姓名、学号、成绩,分别输出成绩最高和成绩最低学生的姓名和学号。输入格式:每个测试输入包含 1 个测试用例,格式为第 1 行:正整数 n第 2 行:第 1 个学生的姓名 学号 成绩第 3 行:第 2 个学生的姓名 学号 成绩… … …第 n+1 行:第 n 个学生的姓名 学号 成绩其中姓名和学号均为不超过 10 个字符的字符串,成绩为 0 到 100 之间的一个整数,这里保证在一组测试用例中没有两个学生的成绩是相同的。#inclu

2020-08-25 15:49:50 85

原创 PAT乙级1003

1003 我要通过! (20分)“答案正确”是自动判题系统给出的最令人欢喜的回复。本题属于 PAT 的“答案正确”大派送 —— 只要读入的字符串满足下列条件,系统就输出“答案正确”,否则输出“答案错误”。得到“答案正确”的条件是:字符串中必须仅有 P、 A、 T这三种字符,不可以包含其它字符;任意形如 xPATx 的字符串都可以获得“答案正确”,其中 x 或者是空字符串,或者是仅由字母 A 组成的字符串;如果 aPbTc 是正...

2020-08-25 15:44:26 76

原创 PAT乙级1001-1002

1001:卡拉兹(Callatz)猜想:对任何一个正整数 n,如果它是偶数,那么把它砍掉一半;如果它是奇数,那么把 (3n+1) 砍掉一半。这样一直反复砍下去,最后一定在某一步得到 n=1。卡拉兹在 1950 年的世界数学家大会上公布了这个猜想,传说当时耶鲁大学师生齐动员,拼命想证明这个貌似很傻很天真的命题,结果闹得学生们无心学业,一心只证 (3n+1),以至于有人说这是一个阴谋,卡拉兹是在蓄意延缓美国数学界教学与科研的进展……我们今天的题目不是证明卡拉兹猜想,而是对给定的任一不超过 1000 的正整

2020-08-25 15:39:47 105

原创 查找排序学习笔记

算法的时间复杂度并不能代表算法的实际执行时间,有些时候看似复杂度高的速度反面快。查找算法:顺序查找:对待查找的数据没有要求,时间复杂度: O(n)二分查找:对待查找的数据必须有序,时间复杂度: O(logn)块查找:是一种数据处理的思想,不是特定的算法,当数据量过多时,可以先把数据进行分块处理,然后再进行查找,例如英语词典。哈希查找:数据 经过哈希函数 计算出数据在哈希表中的位置,然后标记,方便之后的查找,它的时间复试度最快能达到:O(1)。但是该算法有很大局限性,不适合浮点型、字符串型

2020-08-21 14:01:56 132 5

原创 数据类型----树

树型结构:1、树的基本概念一种表示层次关系的(一对多)数据结构。有且仅有一个特定的节点,该节点没有前驱,被称为根节点。剩余的n个互不相交的子集,其中每个子集也都是一棵树,被称为根节点的子树。注意:树型结构具有递归性(树中有树)。2、树的表示方法:倒悬树、嵌套法、凹凸法。3、树的专业术语:节点:组成树的基础元素,同时它也是一棵树。节点的度:该节点子树的数量。树的度(密度):树中节点的数量。叶子节点:节点的度为0的节点。双亲和孩子:节点的子树被称为孩子节点,该节点就是它们的双亲。兄弟:

2020-08-17 10:24:04 337

原创 结构联合枚举的学习笔记

结构:结构是由程序员自己设计一种数据类型,用于描述一个事物的各项数据,由若干个不同的基础类型组成。设计:struct 结构体名{ 类型 成员名; ...};定义结构变量:struct 结构名 变量名;注意:定义结构变量时,struct不能省略。定义结构变量初始化: struct 结构名 变量名 = {v1,v2,v3}; 要根据成员的顺序初始化 struct 结构名 变量名 = {.成员名=va2,.成员名=v3,...}; 只初始化某

2020-07-30 09:18:10 128

原创 简单的推箱子小游戏 C语言实现

一个推箱子的小游戏#include<stdio.h>#include<stdlib.h>#include<getch.h>int main(){ char map[8][8] = { {0,0,3,3,3,3,0,0}, {0,0,3,5,5,3,0,0}, {0,3,3,0,5,3,3,0}, {0,3,0,0,4,5,3,0}, {3,3,0,4,0,0,3,3}, {3,0,0,3,4,4,0,3}, {3,0,0,2,0,0

2020-07-16 16:25:36 173 1

原创 关于递归的一些小练习

递归是什么递归可以实现分治这种算法,就是把一个复杂的大问题,分解成若干个相同的小分问题,直到问题全部解决。递归案例斐波那契数列#include<stdio.h>int get_fibonacci(int number){ //第一个和第二个斐波那契数列值为1 if( 1==number || 2==number ) { return 1; } //第三项开始的斐波那契数列是前2项的和 else {

2020-07-16 16:21:31 125

原创 C语言走迷宫的小游戏项目

自己做的一个数组迷宫小游戏。#include <stdio.h>#include <stdlib.h>#include <getch.h>int main(){ // 迷宫数组 char maze[10][10] = { {'#','#','#','#','#','#','#','#','#','#'}, {'#','@','#','#',' ',' ',' ','#','#','#'}, {'#',' ','#','#',' ','#','

2020-07-16 16:16:53 554

原创 近日的学习笔记 进程印象 局部变量与全局变量 类型限定符

进程映像:程序:存储磁盘上的可执行文件(二进制文件、脚本文件)。进程:正在系统中运行的程序。进程映像指的就是进程的分布情况:text 代码段 存储是二进制指令,常量数据,权限是只读,强制修改会产生段错误。data 数据段 初始化过的全局变量bss 静态数据段 未初始化的全局变量,程序运行时会被清理为0。stack 栈 局部变量、块变量 会随着程序运行不断申请、释放 由于系统管理heap 堆 由程序员手动管理 特点就是够大局部变量和全局变量:局部变量:定义在函数内stack函数调用开

2020-07-15 20:18:06 129

基于C语言编写的2048游戏

基于C语言编写的2048小游戏111111111111111111111111111111111111111111111111111111111111111111

2020-09-22

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除