当前位置: 首页 > news >正文

编程之路,从0开始:补充篇

        Hello大家好!很高兴和大家又见面啦!给生活添点passion,开始今天的编程之路!

1702d5cef00940d18a9d6d4da33b31ba.gif

我的博客:<但凡.

我的专栏:《编程之路》、《题海拾贝》、《数据结构与算法之美》

欢迎点赞,关注!

        这篇文章拖了很久,甚至是在编程之路这个系列完结之后才发出来,主要是想把之前遇到的有意思的小问题一次性给大家说清楚,并做一些拓展。

目录

1、scanf和gets

1.1输入带有空格的字符串

1.2scanf的返回值

2、取模问题

2.1负数取模

2.2取模运算的应用

3、assert断言

4、进制转化

4.1其他进制转十进制

4.2十进制转其他进制

4.3、其他进制转其他进制

5、随机数生成技巧 

6、C/C++程序内存区域划分


1、scanf和gets

我们先尝试运行以下代码:

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int main()
{char p[10] = "";scanf("%s",p);printf("%s", p);gets(p);printf("%s", p);return 0;
}

        我们输入asd fgh,输出asd fgh。

         之所以讨论一下scanf和gets,是因为他们有一定的区别。不知道大家在写代码的时候发现没有,用scanf输入字符串时如果字符串中有空格,他打印的时候不会打印空格及以后的内容。但gets是可以打印出有空格的字符串的。

        知道这个特点后,我们分析一下上面的代码。首先我们输入asd fgh,scanf只能接收到asd,剩下的空格和fgh以及我们输入的\n(回车)他都放入了缓冲区。然后执行gets时我们不用输入,gets直接从缓冲区读取这些内容,然后打印出来。

1.1输入带有空格的字符串

        我们可以用gets函数输入字符串:

#include<stdio.h>
int main()
{char p[100] = "";gets(p);printf("%s",p);return 0;
}

        那么我们如何让scanf也能输出含有空格的字符串呢?我们可以这样写:

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int main()
{char p[100] = "";scanf("%[^\n]",p);printf("%s",p);return 0;
}

输出结果:

59c9c3681ed14904848719c8378269fd.png

        这样我们可以让scanf读取到\n之后再停止。另外如果在vs中使用scanf的话需要写上#define _CRT_SECURE_NO_WARNINGS (如上代码),不然的话需要写scanf_s。

        我们还可以使用fgets来输入字符串。但是要将文件指针换成stdin(标准输入流):

#include<stdio.h>
int main()
{char p[100] = "";fgets(p, 100, stdin);printf("%s",p);return 0;
}

输出结果:

05f4d4b8fe3c4738a89db3778c183b29.png

        此外,输入字符串的方式还可以使用getchar和循环一个一个的输入,只是这样麻烦一些。其实在c++中,我们还可以使用cin来输入字符串,而且在c++中我们更常使用string字符串。当然了很久以后我们还会分享c++的知识,这里只是简单提一下。

1.2scanf的返回值

在vs中使用scanf时经常会出现这个警告:

251435501d8c4a5fa5d5621074163734.png

我们去cplusplus上看一下scanf这个函数的原型:

57faa23f6fb644dc891193ec2218736a.png

        我们发现,其实scanf是有返回值的,而它的返回值就是输入数据的个数。当然了,我们在使用它的时候用到的概率不大。

2、取模问题

2.1负数取模

        不知道大家想过没有,一个负数取模结果是正数还是负数呢?

#include<stdio.h>
int main()
{int a = -10;printf("%d",a%3);return 0;
}

输出结果:

c7ff74f853cc47bd809a14ca5b72c06e.png

        很明显,负数取模结果是负数。那么问题又来了,如果我让10%(-3)呢?

输出结果:

fff1c6f822724bf398a3dc26d1bd9d17.png         经过我们实验可以知道,负数也是支持取模的,但是负数求模结果的正负号由第⼀个运算数(操作数)的正负号决定。

2.2取模运算的应用

我们可以写一个程序,判断一个数是奇数还是偶数:

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int main()
{int a = 0;scanf("%d", &a);if (a % 2 == 1){printf("奇数\n");}elseprintf("偶数\n");return 0;
}

        这个程序对于正数判断奇数偶数没有问题,但是它不能判断负数是奇数还是偶数。

        这个时候我们就可以使用奇数二进制末尾都是1这个特性,进行&运算:

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int main()
{int a = 0;scanf("%d", &a);if (a & 1 == 1){printf("奇数\n");}elseprintf("偶数\n");return 0;
}

        因为&运算是当这个二进制位都为1时,他才为1。那么我们让一个数&1不就能保证其他位都是0,我们只判断最后一个位是不是1了呢?

3、assert断言

        这个东西我之前用到过,但是忘了说。

  assert 是一个,用于在运行时检查一个条件是否为真,如果条件不满足,则运行时将终止程序的执行并输出一条错误信息。

在使用时,我们需要包含头文件:

#include<assert.h>

它常用于判断一个地址为不为空或一个数是不是0。

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<assert.h>
#include<stdlib.h>
int main()
{int* p = NULL;assert(p);return 0;
}

结果:

187a1c9344114a028e5bc40ae86801b0.png

4、进制转化

         常见的进制有二进制,八进制,十进制,十六进制...,那么这些进制之间如何转化呢?

4.1其他进制转十进制

·       其实我们数字的每一位都有自己的权重。比方说十进制123,就等一1*(10^2)+2*(10^1)+1*(10^0)。

我们可以利用这个方法将二进制转化为十进制:

比如101转化为十进制就是1*(2^2)+0*(2^1)+1*(2^0)=5。

        同样的道理我们也可以把八进制和十六进制转化为十进制。

        现在我们来写一个程序将x进制转化为十进制:

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
#include<math.h>//使用pow
int main()
{int x = 0;printf("请输入想要转化的数的进制:");scanf("%d", &x);if (x > 36){printf("输入错误\n");return 0;}char s[100] = "";//因为有可能含有大写字符,所以定义为char类型数组printf("请输入被转化数:");scanf("%s", &s);int len = strlen(s);int ret = 0;int j = 0;while(len--)//每次进入循环len自减1{if(s[len]<'9'){ret=ret+(s[len] - '0')* pow(x,j);//当操作数为数字时j++;}else{ret=ret+ (s[len] - 'A'+10) * pow(x, j);//当操作数为字母时j++;}}printf("%d", ret);return 0;
}

输出结果:

60315ee22e524c18a59be43182b5fe12.png

82b59ca3c4304c6bb7df6cfcd99fa254.png

        当大于十进制时,被转化的数中就会含有ABC这样的大写字母,所以我们在进行计算时要分情况讨论。另外当进制大于36时输入错误,因为最大就10加二十六个字母,也就是说最大进制就是36(除非他用其他的字符继续表示)。

        在c++中,我们可以对stoi函数进行改造,使他支持进制转换。当然这里只是拓展一下,想了解的朋友自行了解哈~

4.2十进制转其他进制

        我们这里那十进制转二进制举例:

a4eabd364c734214a623379439581995.png

注:画的很丑请见谅~

         其实就是让这个十进制数除以想要转化的进制,记录余数,然后再那除完的结果继续去除......但需要注意的是,这些余数我们需要从下往上写(对应上图)。

所以我们就可以用递归的思想实现这个代码:

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
char s[38] = "012345678910ABCDEFGHIJKLMNOPQRSTUVWXYZ";
void itox(int n,int x)
{if(n>=x){itox(n / x, x);//递归}printf("%c", s[n % x]);
}
int main()
{int n = 0;printf("请输入被转化数:");scanf("%d", &n);int x = 0;printf("请输入想要转化成的进制:");scanf("%d", &x);itox(n,x);return 0;
}

        还是由于可能会出现大写字母,所以我们定义一个全局的字符数组,存入一到九和A到Z。

以后我们就可以把这串代码当作一个模板,进制转化的时候直接套用就好了。

4.3、其他进制转其他进制

        这个我们就可以把上面的两个代码改造一下,自己输入两个进制数,先将数转化成十进制数,再将十进制数转化为其他进制数:

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
#include<math.h>//不要忘记
char s[38] = "012345678910ABCDEFGHIJKLMNOPQRSTUVWXYZ";
int  ntoi(int n, char a[100])
{int len = strlen(a);int ret = 0;int j = 0;while (len--){if (a[len] < '9'){ret = ret + (a[len] - '0') * pow(n, j);j++;}else{ret = ret + (a[len] - 'A' + 10) * pow(n, j);j++;}}return ret;
}
void itox(int a,int x)
{if(a>=x){itox(a / x, x);//递归}printf("%c", s[a % x]);
}
int main()
{int n = 0;printf("请输入被转化数的进制:");scanf("%d", &n);char a[100] = "";printf("请输入被转化数:");scanf("%s",a);int x = 0;printf("请输入想要转化成的进制:");scanf("%d", &x);int ret=ntoi(n,a);//将a转化为十进制itox(ret,x);//将十进制的a转化为x进制return 0;
}

测试:

f9eb2408a1894d00b59a174d96a83440.png

2a2fa6edb4a242d5b7edafcf62e37ab6.png

5、随机数生成技巧 

        现在我们用C语言实现随机数:

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<time.h>
#include<stdlib.h>//使用srand
int main()
{srand((unsigned int)time(NULL));printf("%d", rand()%10);return 0;
}

        其实这个随机数理应是初学C语言时接触的,但是我给忘了哈哈,所以在这里再说一下,而且现在我们再看这个随机数生成操作其实是更好理解的。

首先先看srand:

ef0742f102f44f638024cbf3b65a73a8.png

        我们应该把种子传入这个函数,但是如果种子不变的话数也是不变的啊!那有没有什么东西是一直改变的呢?没错,就是时间戳。

        时间戳,是从1970年1月1日(UTC/GMT的午夜)开始所经过的秒数(不考虑闰秒),用于表示一个时间点。然而,这种格式对于人类阅读并不友好,因此需要转换成可读的日期和时间格式。 

        我们只需知道,时间戳是随着时间一直快速变化的,所以我们把它作为种子传入srand。又由于他的参数需要是unsigned int 类型的,所以我们强制转化一下。

        接着调用rand(),我们想他有一个范围,就%这个范围的最大值可以了,比如如上代码是生成0~9范围的随机数。我们写成rand()%10+1就是1~10范围的随机数。

6、C/C++程序内存区域划分

cf001efc9da64e3883a6cbe608ea3f61.png

        C/C++程序内存分配的几个区域:

        1. 栈区(stack):在执⾏函数时,函数内局部变量的存储单元都可以在栈上创建,函数执⾏结束时 这些存储单元⾃动被释放。栈内存分配运算内置于处理器的指令集中,效率很⾼,但是分配的内 存容量有限。栈区主要存放运⾏函数⽽分配的局部变量、函数参数、返回数据、返回地址等。 

        2. 堆区(heap):⼀般由程序员分配释放,若程序员不释放,程序结束时可能由OS(操作系统) 回收。分配⽅式类似于链表。

        3. 数据段(静态区):(static)存放全局变量、静态数据。程序结束后由系统释放。

        4. 代码段:存放函数体(类成员函数和全局函数)的⼆进制代码。

好了,今天的内容就分享到这,我们下期再见!

相关文章:

编程之路,从0开始:补充篇

Hello大家好&#xff01;很高兴和大家又见面啦&#xff01;给生活添点passion&#xff0c;开始今天的编程之路&#xff01; 我的博客&#xff1a;<但凡. 我的专栏&#xff1a;《编程之路》、《题海拾贝》、《数据结构与算法之美》 欢迎点赞&#xff0c;关注&#xff01; 这篇…...

<script src = “https://cdn.jsdelivr.net/npm/vue/dist/vue.js“></script>

这行代码是HTML中的一个<script>标签&#xff0c;用于在网页中嵌入Vue.js库。具体来说&#xff1a; <script>&#xff1a;是HTML中的一个标签&#xff0c;用于定义客户端的脚本&#xff0c;比如JavaScript。 src&#xff1a;是<script>标签的一个属性&#…...

RabbitMQ延时队列

RabbitMQ延时队列 什么是延时队列 延时队列顾名思义&#xff0c;即放置在该队列里面的消息是不需要立即消费的&#xff0c;而是等待一段时间之后取出消费。 应用场景 场景一&#xff1a;在订单系统中&#xff0c;一个用户下单之后通常有30分钟的时间进行支付&#xff0c;如…...

Java——异常机制(下)

1 异常处理之(捕获异常) (一般处理运行时异常) (try-catch-finally子句) (finally一般用于文件最后关闭) (catch捕获的子类在前父类在后——>不然父类在前面都让父类捕获掉了&#xff0c;会报错) (Exception是父类放在最后&#xff0c;如果前面没有捕获到&#xff0c;就…...

9. 一分钟读懂“策略模式”

9.1 模式介绍 策略模式是一种行为型设计模式&#xff0c;用于在运行时灵活切换对象的行为或算法&#xff0c;它将算法封装为独立的类&#xff0c;使得它们可以互相替换&#xff0c;而不会影响使用这些算法的客户端代码。 策略模式的核心思想是&#xff1a;定义一系列可互换的算…...

python调用GPT-4o实时音频 Azure OpenAI GPT-4o Audio and /realtime

发现这块网上信息很少&#xff0c;记录一下 微软azure入口 https://learn.microsoft.com/zh-cn/azure/ai-services/openai/realtime-audio-quickstart?pivotsprogramming-language-ai-studio sdk文档 https://github.com/azure-samples/aoai-realtime-audio-sdk?tabread…...

linux查看应用程序执行时间

命令 ps -eo pid,comm,lstart,etime,args | grep -i java ps&#xff1a;是查看进程状态的命令。-eo&#xff1a;是-e和-o参数的组合&#xff0c;-e表示显示所有进程&#xff0c;-o后面跟的是自定义输出格式。pid&#xff1a;表示进程ID。comm&#xff1a;表示命令名&#x…...

mybatis之数据统计与自定义异常处理

文章目录 需求描述定义实体方式一、mybatisPlus实现方式二、自定义SQL实现简单查询过滤查询 异常处理1、SQL拼写异常 在使用Mybatis或MybatisPlus进行数据统计&#xff0c;在【 SpringBoot的Mybatis-plus实战之基础知识】中对mybatisplus引入有介绍&#xff0c;本次要使用其进…...

Jenkins 中自定义Build History中显示构建信息

有时候会遇到一个代码仓库下面会有多个不同的分支&#xff0c;而这写分支表示着不同的开发者在开发新的需求&#xff0c;但是这样就会出现一个问题&#xff0c;在Jenkins上进行多分支构建的时候&#xff0c;很难找到哪一个是属于自己分支构建的&#xff0c;这样的问题大家应该都…...

安装certbot(ubuntu系统)

安装nginx 更新软件包列表 sudo apt update 更新软件包列表 sudo apt install nginx 更新软件包列表 sudo systemctl status nginx 注意&#xff1a;强烈推荐使用&#xff0c;系统直接安装nginx&#xff0c;&#xff08;不推荐使用docker安装nginx&#xff09;为后续更简单…...

QTextBrowser按照段落来显示html的文字

在 PyQt5 中&#xff0c;QTextBrowser 是一个用来显示富文本&#xff08;如 HTML&#xff09;内容的小部件。要让 QTextBrowser 按照段落来显示 HTML 内容&#xff0c;可以确保 HTML 中的每个段落被正确地封装在 <p> 标签中或其他合适的 HTML 标签中。 基本思路 HTML 格…...

如何让Google快速收录你的页面?

要让Google更快地收录你的网站内容&#xff0c;首先需要理解“爬虫”这个概念。Google的爬虫是帮助它发现和评估网站内容质量的工具&#xff0c;如果你的页面质量高且更新频率稳定&#xff0c;那么Google爬虫更可能频繁光顾。通常情况下&#xff0c;通过Google Search Console&…...

用Linux完成firewall-cmd配置防火墙

注意这里是openeuler的系统 假设在内网架设了一台Web服务器,IP地址是192.168.1.2,端口是80,设置内网网段192.168.1.0/24中的主机均可以访问此Web服务器,如图所示 步骤如下&#xff08;包含结果&#xff09; 这里再服务端&#xff08;192.168.131.10&#xff09;上配置&#x…...

关于光速的猜想

光速实际也可能是爱因斯坦制造出来的一个量&#xff0c;就像质量&#xff08;重力mg&#xff0c;有这个关系在&#xff0c;m起的名字后来就演变成了质量&#xff09;是牛顿造出的一个量&#xff0c;一个常量&#xff0c;刚开始都叫c&#xff0c;只是习以为常后起了个名字罢了&a…...

Mybatis-Flex的简单入门,Mybatis-Flex和其它框架对比

前言 最近做项目&#xff0c;项目组必须要用Mybatis-Flex&#xff0c;然后自己去学了一下&#xff0c;给大家进行分享。 MyBatis-Flex 是 MyBatis 的一个增强工具&#xff0c;旨在简化 MyBatis 的使用并提高开发效率。它通过提供一系列的便捷方法和特性来减少重复代码的编写&am…...

轻量化特征融合 | YOLOv11 引入一种基于增强层间特征相关性的轻量级特征融合网络 | 北理工新作

本改进已同步到Magic框架 摘要—无人机图像中的小目标检测由于分辨率低和背景融合等因素具有挑战性,导致特征信息有限。多尺度特征融合可以通过捕获不同尺度的信息来增强检测,但传统策略效果不佳。简单的连接或加法操作无法充分利用多尺度融合的优势,导致特征之间的相关性不…...

linux的磁盘管理

认识磁盘 从外到内&#xff0c;磁道从0~XXX。扇区默认512字节先读完一个柱面的0号磁道&#xff0c;接着读第二个柱面的0号磁道……直至所有柱面的0号磁道读写完毕&#xff0c;进入下一个磁道。 磁盘命名规则 物理磁盘:sd开头&#xff1b;虚拟磁盘vd开头 sdb1&#xff1a;第二…...

Alibaba EasyExcel 导入导出全家桶

一、阿里巴巴EasyExcel的优势 首先说下EasyExcel相对 Apache poi的优势&#xff1a; EasyExcel也是阿里研发在poi基础上做了封装&#xff0c;改进产物。它替开发者做了注解列表解析&#xff0c;表格填充等一系列代码编写工作&#xff0c;并将此抽象成通用和可扩展的框架。相对p…...

使用Scala编写一个简单的决策树分类测试demo

使用Scala编写一个简单的决策树分类测试demo&#xff0c;我们可以基于Apache Spark的MLlib库来实现。这里将展示如何创建一个简单的决策树分类器&#xff0c;并用它来进行预测。我们将遵循以下步骤&#xff1a; 设置环境和导入必要的包。加载并准备数据集。构建决策树模型。使…...

SQLServer中使用ISNULL替换为指定的替换值

ISNULL (Transact-SQL) 适用于&#xff1a; SQL ServerAzure SQL 数据库Azure SQL 托管实例Azure Synapse Analytics 分析平台系统 (PDW)Microsoft Fabric 中的 SQL 分析端点Microsoft Fabric 中的仓库 NULL替换为指定的替换值。 1、语法 ISNULL ( check_expression , rep…...

69 mysql 中 is null 的实现

前言 Mysql 中我们偶尔会用到 字段为 NULL 的情况 这时候 我们只能使用查询 “select * from tz_test_02 where field1 is null;” 来进行 field1 字段为 null 的行的查询 然后如果是使用 “select * from tz_test_02 where field1 null;” 你会发现查询 不出数据 但是如…...

【信息系统项目管理师】第9章:项目范围管理-基础和过程 考点梳理

文章目录 9.1 管理基础9.1.1 产品范围和项目范围9.1.2 管理新实践 9.2 项目范围管理过程9.2.1 过程概述9.2.2 裁剪考虑因素9.2.3 敏捷与适应方法 【学习建议】本章节内容属于10大管理知识领域&#xff0c;选择、案例、论文都会考&#xff0c;建议重点学习。项目范围管理包括确保…...

智能制造标准体系建设指南

一、智能制造系统架构总览 智能制造作为当今制造业转型升级的核心&#xff0c;深度整合了新一代信息技术与传统制造工艺&#xff0c;催生出一个横跨产品全生命周期、纵贯多层级组织架构&#xff0c;并彰显多元智能特性的复杂系统。这一架构从生命周期、系统层级、智能特征三个…...

怎么获取键值对的键的数值?

问&#xff1a; 通过paelData.cardMap.C0002112可以获取到Cooo2112里面的数据&#xff0c;但是有时候接口返回的不是C0002112而是C0002093或者其他值&#xff0c;请问我该怎么写&#xff1f; 后端返回的数据是这样的&#xff1a; cardMap: { C0002112: { name: Item 1, va…...

反向代理后Request.Url.AbsoluteUri获取成了内网IP

出现的问题&#xff1a;用户请求的是域名&#xff0c;而后端通过Request.Url.AbsoluteUri获取用户请求的绝对路径时&#xff0c;变成了内网IP 解决方式&#xff1a; 反向代理配置中加上&#xff1a; proxy_set_header Host $host; # proxy_set_header Host h o s t : host: h…...

NLP论文速读(斯坦福大学)|使用Tree将语法隐藏到Transformer语言模型中正则化

论文速读|Sneaking Syntax into Transformer Language Models with Tree Regularization 论文信息&#xff1a; 简介&#xff1a; 本文的背景是基于人类语言理解的组合性特征&#xff0c;即语言处理本质上是层次化的&#xff1a;语法规则将词级别的意义组合成更大的成分的意义&…...

OpenCV-图像阈值

简单阈值法 此方法是直截了当的。如果像素值大于阈值&#xff0c;则会被赋为一个值&#xff08;可能为白色&#xff09;&#xff0c;否则会赋为另一个值&#xff08;可能为黑色&#xff09;。使用的函数是 cv.threshold。第一个参数是源图像&#xff0c;它应该是灰度图像。第二…...

window系统,照片应用打开图片,但是提示操作系统找不到已输入的环境选项,请问怎么解决,以便能打开图片

文章目录 问题描述问题解决一、先用AI提问&#xff0c;看能否得到解答二、最终的解决方法-修改环境变量 至此问题解决。 问题描述 Windows中&#xff0c;使用默认的图片应用打开图片时&#xff0c;提示&#xff1a; 操作系统找不到已输入的环境选项如下图&#xff1a; 这个问…...

Excel之查找函数-XLOOKUP

背景&#xff1a; 某些数据处理&#xff0c;需要对比两个乱序或者数据不完全相同的数值&#xff0c;取到另外一个数据值&#xff0c;数据量大的情况下&#xff0c;人工对比太耗时&#xff0c;XLOOKUP函数是一个查找函数&#xff0c;可以通过遍历对比某一单元格的值&#xff0c…...

深入理解 Java 内存管理:堆和栈

深入理解 Java 内存管理&#xff1a;堆和栈的全面解析 在 Java 编程语言中&#xff0c;内存管理是一个至关重要的概念&#xff0c;其中堆&#xff08;Heap&#xff09;和栈&#xff08;Stack&#xff09;是两个核心的内存区域。理解它们的工作原理、用途以及它们在程序执行过程…...

深度全解析开放开源大模型之BLOOM

BLOOM是 BigScience Large Open-science Open-access Mul-tilingual Language Model首字母的缩写。 BigScience 不是财团&#xff08;consortium&#xff09;&#xff0c;也不是正式成立的实体。这是一个由HuggingFace、GENCI和IDRIS发起的开放式协作组织&#xff0c;以及一个…...

下载谷歌浏览器的官方离线安装包

网址&#xff1a;https://support.google.com/chrome/answer/95346?hlzh-Hans&coGENIE.Platform%3DDesktop#zippy%2Cwindows...

ORACLE创建用户报错ORA-65096: invalid common user or role name

在高版本的oracle中创建用户时提示错误ORA-65096: invalid common user or role name&#xff0c;官网说明用户名必须使用C##或c##开头。以下方法亲测有效。 通过设置"_ORACLE_SCRIPT"参数为true来临时绕过CDB中创建用户必须以"C##"开头的限制。请注意&…...

河工oj第七周补题题解2024

A.GO LecturesⅠ—— Victory GO LecturesⅠ—— Victory - 问题 - 软件学院OJ 代码 统计 #include<bits/stdc.h> using namespace std;double b, w;int main() {for(int i 1; i < 19; i ) {for(int j 1; j < 19; j ) {char ch; cin >> ch;if(ch B) b …...

运维大屏与设备仪表盘:打造高效运维管理的视觉中枢

在快速发展的信息化时代&#xff0c;运维行业面临着前所未有的挑战。随着业务规模的不断扩大和系统复杂度的日益增加&#xff0c;如何高效、准确地监控和管理设备运行状态&#xff0c;成为运维团队亟待解决的问题。运维大屏与设备仪表盘作为运维管理的重要工具&#xff0c;为运…...

计算机视觉与医学的结合:推动医学领域研究的新机遇

目录 引言医学领域面临的发文难题计算机视觉与医学的结合&#xff1a;发展趋势计算机视觉结合医学的研究方向高区位参考文章结语 引言 计算机视觉&#xff08;Computer Vision, CV&#xff09;技术作为人工智能的重要分支&#xff0c;已经在多个领域取得了显著的应用成果&…...

使用setsockopt函数SO_BINDTODEVICE异常,Protocol not available

前言 最近在使用OLT的DHCP Server的时候发现一些异常现象&#xff0c;就是ONU发的一个vlan的discover包其他不同vlan的DHCP地址池也会收到&#xff0c;导致其他服务器也发了offer包&#xff0c;ONU同时会有多个ip地址。一开始是没有使用SO_BINDTODEVICE&#xff0c;后面查到使…...

rpm包转deb包或deb包转rpm包

Debian系&#xff08;Ubuntu、Deepin、麒麟Destop等&#xff09;用的安装包是deb的&#xff0c;Red Hat系&#xff08;CentOS、欧拉、麒麟Server等&#xff09;用的安装包是rpm的。 如果需要在Ubuntu上安装rpm&#xff0c;或需要在CentOS上安装deb&#xff0c;需要安装alien s…...

ChatGPT 和文心一言哪个更好用?

ChatGPT vs 文心一言&#xff1a;哪个更好用&#xff1f; 引言 在人工智能蓬勃发展的今天&#xff0c;聊天机器人已经成为我们生活和工作中不可或缺的一部分。你可能听说过ChatGPT和文心一言这两个热门的聊天机器人&#xff0c;它们分别来自OpenAI和百度。那么&#xff0c;究…...

T113-S3 Tina 存储类型修改

前面介绍了如何在 Tina 中添加新的板子&#xff0c;本节介绍如何修改板子存储类型。 1、确定存储类型 Tina 支持多种存储类型&#xff0c;包括 SD 卡、eMMC、SPI NAND、SPI NOR 等。在添加板子之前&#xff0c;需要确定板子使用的存储类型。 存储类型修改 在 device/config/…...

【css】基础(一)

本专栏内容为&#xff1a;前端专栏 记录学习前端&#xff0c;分为若干个子专栏&#xff0c;html js css vue等 &#x1f493;博主csdn个人主页&#xff1a;小小unicorn ⏩专栏分类&#xff1a;css专栏 &#x1f69a;代码仓库&#xff1a;小小unicorn的代码仓库&#x1f69a; &a…...

Linux中inode

磁盘的空间管理 如何对磁盘空间进行管理&#xff1f; 假设在一块大小为500G的磁盘中&#xff0c;500*1024*1024524288000KB。在磁盘中&#xff0c;扇区是磁盘的基本单位&#xff08;一般大小为512byte&#xff09;&#xff0c;而文件系统访问磁盘的基本单位是4KB&#xff0c;因…...

verilog fpga 如果if语句==号后面是个表达式 运行不稳定

来自 文心一言 在Verilog中编写FPGA代码时&#xff0c;使用if语句进行条件判断是常见的操作。然而&#xff0c;当if语句中的条件判断使用的是表达式&#xff08;如后面是一个复杂的表达式&#xff09;&#xff0c;确实可能会遇到运行不稳定的问题。这通常是由于以下几个原因导…...

BFS广度优先搜索

广度优先搜索&#xff08;Breadth-First Search, BFS&#xff09;是一种用于遍历或搜索树或图的算法。 它从根节点开始&#xff0c;逐层访问每个节点&#xff0c;并在访问完一层后才访问下一层。BFS常用于寻找最短路径的问题。 下面将用实例一和实例二来实现BFS广度优先搜索 …...

uniapp 自定义导航栏增加首页按钮,仿微信小程序操作胶囊

实现效果如图 抽成组件navbar.vue&#xff0c;放入分包 <template><view class"header-nav-box":style"{height:Props.imgShow?:statusBarHeightpx,background:Props.imgShow?:Props.bgColor||#ffffff;}"><!-- 是否使用图片背景 false…...

小程序项目的基本组成结构

分类介绍 项目根目录下的文件及文件夹 pages文件夹 用来存放所有小程序的页面&#xff0c;其中每个页面都由4个基本文件组成&#xff0c;它们分别是&#xff1a; .js文件&#xff1a;页面的脚本文件&#xff0c;用于存放页面的数据、事件处理函数等 .json文件&#xff1a;…...

2020年国赛高教杯数学建模E题校园供水系统智能管理解题全过程文档及程序

2020年国赛高教杯数学建模 E题 校园供水系统智能管理 原题再现 校园供水系统是校园公用设施的重要组成部分&#xff0c;学校为了保障校园供水系统的正常运行需要投入大量的人力、物力和财力。随着科学技术的发展&#xff0c;校园内已经普遍使用了智能水表&#xff0c;从而可以…...

《C++与 OpenCV 机器学习模块:目标检测的强大融合》

在当今科技飞速发展的时代&#xff0c;目标检测技术已经成为计算机视觉领域的一颗璀璨明珠&#xff0c;广泛应用于安防监控、自动驾驶、智能图像分析等众多领域。而 C语言凭借其高效性和强大的性能&#xff0c;与 OpenCV 的机器学习模块相结合&#xff0c;为实现精准且高效的目…...

函数与模块

目录 1.函数 1.1.函数概念 1.2.函数定义 1.3.函数分类 1.4.函数参数类型 1.4.1.位置参数 1.4.2.关键字参数 1.4.3.默认值参数 1.4.4.可变参数 1.5.匿名函数 1.6.参数传递问题 2.冒泡排序 2.1.冒泡排序规则 2.2.冒泡排序实现 3.math 模块 4.random 模块 5.date…...

SQL面试题——滴滴SQL面试题 取出累计值与1000差值最小的记录

滴滴SQL面试题 取出累计值与1000差值最小的记录 今天的题目来自滴滴出行 已知有表cost_detail包含id和money两列,id为自增,请累加计算money值,并求出累加值与1000差值最小的记录。 +-----+--------+ | id | money | +-----+--------+ | 1 | 200 | | 2 | 300 …...