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

【C语言】详解计算机二级c语言程序题

文章目录

  • 前言
  • 资料相关
  • 程序题 一(字符串)
  • 程序题 二(数组)
  • 程序题 三(基础)
  • 程序题 四(结构体)
  • 程序题 五(结构体)
  • 程序题 六(基础)

前言

最近计算机二级的c语言快要考试了,我从网上摘抄了一些c语言二级的原题,并利用gpt做了一些解析来理解这些问题,以便大家能够更好的学习。

同时,我将问题答案设置为白色(只需要选中就可以查看),大家可以在理解问题的同时进行练习。

资料相关

  1. Dotcpp——里面有C语言原题以及众多高校试卷,可以用来练习
  2. 计算机二级考试官网——没有报名的同学千万别忘了
    各省份报考时间
  3. 资源绑定里面有c语言计算机二级的考纲(2023版)

程序题 一(字符串)

给定程序中,函数fun的功能是:在形参s所指字符串中寻找与参数c相同的字符,并在其后插入一个与之相同的字符,若找不到相同的字符则函数不做任何处理。

例如,s所指字符串为:baacda,c中的字符为:a,执行后s所指字符串为:baaaacdaa。

请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。

注意:源程序存放在考生文件夹下的BLANK1.C中。

不得增行或删行,也不得更改程序的结构!

#include<stdio.h>
void fun(char *s, char c)
{int i, j, n;for(i=0; s[i]!=___1___ ; i++)if(s[i]==c){n=___2___ ;while(s[i+1+n]!='\0') n++;for(j=i+n+1; j>i; j--) s[j+1]=s[j];s[j+1]=___3___ ;i=i+1;}
}
int main()
{char s[80]="baacda", c;printf("\nThe string: %s\n",s);printf("\nInput a character: ");scanf("%c",&c);fun(s,c);printf("\nThe result is: %s\n",s);return 0;
}
  1. 正确答案: ‘\0’
  2. 正确答案: 0
  3. 正确答案: c
  • fun 函数接受一个字符串 s 和一个字符 c 作为参数。

  • for 循环遍历字符串 s 直到遇到字符串结束符 \0

  • 在循环中,如果当前字符与目标字符 c相等,就执行以下操作:

    • 初始化变量 n 为 0。
    • 使用 while 循环找到目标字符后的子串的长度,即 n
    • 从字符串末尾开始,将原字符串中的字符向后移动一个位置,为插入字符 c 空出位置。
    • 在原字符位置插入字符 c
      更新循环变量 i,以跳过刚刚插入的字符,避免重复处理。
  • main 函数中声明一个字符串 s 并初始化为 "baacda",然后接受用户输入的字符 c

    • 调用 fun 函数对字符串进行处理。最后打印处理后的字符串。

所以,如果用户输入字符 a,程序将在字符串中找到每个 a,并在其后插入一个额外的 a,最终输出结果为 “baaaacdaa”。

程序题 二(数组)

在主函数中从键盘输入若干个数放入数组中,用0结束输入并放在最后一个元素中。给定程序MODI1.C中函数fun的功能是:计算数组元素中值为正数的平均值(不包括0)。

例如:数组中元素中的值依次为:39,-47,21,2,-8,15,0,则程序的运行结果为:19.250000。

请改正程序中的错误,使它能得出正确的结果。

注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!

#include<stdio.h>
double fun ( int x[])
{____1____int c=0, i=0;while (x[i] != 0){if (x[i] > 0){sum += x[i]; c++;}i++;}____2____return sum;
}
int main()
{int x[1000];int i=0;printf( "\nPlease enter some data (end with 0): " );do{scanf("%d", &x[i]);}while (x[i++] != 0);printf("%f\n", fun ( x ));return 0;
}
  1. 正确答案: double sum=0;
  2. 正确答案: sum /= c;
  • 函数 fun:

    • double fun(int x[]): 这是一个函数原型,接受一个整数数组 x 作为参数,返回一个双精度浮点数(double)表示正数的平均值。
    • double sum = 0.0;: 在函数内部声明一个 sum 变量并初始化为0.0,用于存储正数的总和。
    • int c = 0, i = 0;: 声明两个整数变量 ci,其中 c 用于计数正数的个数,i 用于迭代数组元素。
    • while (x[i] != 0): 进入一个 while 循环,循环条件是数组元素不等于0。这是因为输入的数组以0作为结束标志。
    • if (x[i] > 0) { sum += x[i]; c++; }: 如果当前数组元素为正数,则将其加到 sum 中,并增加正数计数器 c
    • i++;: 增加迭代器 i,移动到下一个数组元素。
    • sum /= c;: 计算正数的平均值,将总和 sum 除以正数的个数 c
    • return sum;: 返回计算得到的正数平均值。
  • 主函数 main

    • int x[1000];: 在主函数中声明一个大小为1000的整数数组 x
    • int i = 0;: 声明整数变量 i,用于迭代数组元素的索引。
    • printf("\nPlease enter some data (end with 0): ");: 打印提示信息,要求用户输入数据,直到输入0为止。
    • do { scanf("%d", &x[i]); } while (x[i++] != 0);: 使用 do-while 循环从键盘读取整数,将它们存储到数组中,直到输入0为止。注意,这里使用 i++ 来实现读取下一个数组元素,并检查该元素是否为0来决定是否继续循环。
    • printf("%f\n", fun(x));: 调用 fun 函数计算数组中正数的平均值,并使用 printf 打印结果。

程序题 三(基础)

编写函数fun,函数的功能是:根据以下公式计算s,计算结果作为函数值返回;n通过形参传入。

S = 1 + 1 1 + 2 + 1 1 + 2 + 3 + … + 1 1 + 2 + 3 + … + n S = 1 + \frac{1}{1+2} + \frac{1}{1+2+3} + \ldots + \frac{1}{1+2+3+ \ldots + n} S=1+1+21+1+2+31++1+2+3++n1

例如:若n的值为11时,函数的值为:1.833333

注意:部分源程序在文件PROG1.C中。

请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。

给定源程序:

#include<stdio.h>
float fun(int n)
{____1________2____for(____3____){____4____for(____5____)t+=j;____6____}return s;
}
main()
{int n;float s;printf("\nPlease enter N:");scanf("%d", &n);s = fun(n);printf("the result is: %f\n", s);
}
  1. 正确答案: int i, j, t;
  2. 正确答案: float s=0;
  3. 正确答案: i=1;i<=n;i++
  4. 正确答案: t=0;
  5. 正确答案: j=1;j<=i;j++
  6. 正确答案: s=s+1./t;
  • 变量声明:int i, j, t; float s = 0; 在fun函数开始处,声明了三个整型变量 ijt,以及一个浮点型变量 s。这些变量用于循环和计算。

  • 循环

    • 外部循环:for (i = 1; i <= n; i++),使用 for 循环,变量 i 从1开始递增,直到达到传入的 n 的值。

    • 内部循环:for (j = 1; j <= i; j++);在外部循环中,使用 for 循环,变量 j 从1开始递增,直到达到 i 的值。这个内部循环用于计算公式中的分母部分的和。

      • 内部循环中的累加:t += j; 在内部循环中,变量 t 用于累加 j 的值,即计算公式中的分母部分的和。
    • 计算公式中的分数部分:s += 1.0 / t; 在每次外部循环结束时,通过将1除以 t 的值,得到公式中的分数部分,然后将其累加到变量 s 中。

  • 返回最终结果:return s; 函数 fun 返回计算得到的 s 的值。

  • 用户输入和输出:

    int main()
    {// ...printf("\nPlease enter N:");scanf("%d", &n);s = fun(n);printf("The result is: %f\n", s);// ...
    }
    

    主函数负责接收用户输入的 n,调用 fun 函数计算结果,并输出最终的计算结果。

程序题 四(结构体)

给定程序BLANK1.C中,函数fun的功能是在数组中找出两科成绩之和最高的学生并返回其在数组中的下标。对所给函数int fun(STU*d,int n),主函数传给形参d的是学生数组名,而传给形参n的是该数组中学生的个数。

例如,若学生数组数据为:
2016500301李清水83 92
2016500336 刘世才85 94
2016500371王子晨88 88

则调用该函数后,程序输出为:2016500336刘世才85 94

请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。

注意:不得增行或删行,也不得更改程序的结构!

#include<stdio.h>
typedef struct stu
{char ID[30];char name[20];int score[2];
} STU;
int fun(STU *d,int n)
{int i,m;/******found******/______(1)______;for(i=1;i<n;i++)/******found******/if(d[i].score[0]+d[i].score[1]>________(2)________)m=i;/******found******/______(3)______;
}void main()
{STU a[10]={ "2016500301","李清水",83,92,"2016500336","刘世才",85,94,"2016500371","王子晨",88,88};int i,n=3;i=fun(a,n);printf("%30s%20s%4d%4d",a[i].ID,a[i].name,a[i].score[0],a[i].score[1]);printf("\n");
}
  1. 正确答案: m=0
  2. 正确答案: d[m].score[0]+d[m].score[1]
  3. 正确答案: return m
  • 结构体定义:

    typedef struct stu
    {char ID[30];char name[20];int score[2];
    } STU;
    

    定义了一个结构体 stu,用于存储学生的信息,包括学号(ID)、姓名(name)和两科成绩(score)。

  • 函数定义:

    int fun(STU *d, int n)
    {int i, m;/******found******/m = 0; // 初始化 m 为数组的第一个学生的下标for (i = 1; i < n; i++)/******found******/if (d[i].score[0] + d[i].score[1] > d[m].score[0]+d[m].score[1])m = i; // 更新 m 为当前学生的下标,如果其成绩之和更高/******found******/return m; // 返回最终找到的学生的下标
    }
    

    函数 fun 接收一个指向学生数组的指针 d 和数组中学生的个数 n。函数通过遍历数组找到两科成绩之和最高的学生,并返回其在数组中的下标。

  • 主函数中的调用和输出:

    void main()
    {STU a[10] = { "2016500301", "李清水", 83, 92, "2016500336", "刘世才", 85, 94, "2016500371", "王子晨", 88, 88 };int i, n = 3;i = fun(a, n);printf("%30s%20s%4d%4d", a[i].ID, a[i].name, a[i].score[0], a[i].score[1]);printf("\n");
    }
    

    在主函数中,定义了一个包含三个学生信息的数组 a,然后调用了 fun 函数,得到两科成绩之和最高的学生的下标,最后输出该学生的信息。

程序题 五(结构体)

给定程序MODI1.C中,函数void list(MYDATA *h)的功能是:列出带头结点单链表中所有没有删除标记的数据。调用这个函数时,传给形参h的是指向单链表头结点的指针。

例如,当10个结点的数据为1,2,3,4,5,6,7,8,9,10时,输出将是:3 4 6 7 8 9 10

其中,各个数据所对应的删除标记是由随机数产生的。

请改正函数list中指定部位的错误,使它能得出正确的结果。

注意:不要改动main函数和creat函数,不得增行或删行

#include<stdio.h>
#include<stdlib.h>
typedef struct dat
{char deleted;  //是否删除:0-未删除,1-删除int data;struct dat* next;
} MYDATA;
void list(MYDATA *h)
{
/******found******/MYDATA  p;p=h->next;while(p!=NULL){/******found******/if(p->data==0){printf("%d  ",p->data);}
/******found******/p=next;}
}void creat(MYDATA *h,int *d,int n)
{MYDATA *p, *q;int i=0,del;q=h;while(n>0){p=( MYDATA *)malloc(sizeof(MYDATA));del=rand()%2;p->data=d[i];p->deleted=del;p->next=q->next;q->next=p;q=p;n--;i++;}
}
void main()
{MYDATA *head;int n=10,dd[]={1,2,3,4,5,6,7,8,9,10};head=(MYDATA *)malloc(sizeof(MYDATA));head->next=NULL;creat(head,dd,n);list(head);
}
  1. 正确答案: MYDATA *p;
  2. 正确答案: if(p->deleted==0)
  3. 正确答案: p=p->next;
  • 函数定义:void list(MYDATA *h){ /* ... */} 函数 list 的目标是列出带头结点单链表中没有删除标记的数据。

  • 局部变量声明:MYDATA *p; p=h->next; 在函数内部声明了一个 MYDATA 类型的结构指针变量 p,并将其初始化为链表的第一个结点。

  • 遍历链表:while(p!=NULL){ /* ... */ } 使用 while 循环遍历链表,访问每个结点的数据。

  • 判断删除标记:if(p->deleted==0) { printf("%d ",p->data); } 在循环中,如果当前结点的数据没有删除标记,就输出该数据。

  • 移动到下一个结点:p=p->next;移动到链表中的下一个结点。这里应该使用 p=p->next; 来正确更新 p。

  • 主函数中的调用和输出:list(head);在主函数中调用 list 函数,输出链表中没有删除标记的数据。

程序题 六(基础)

请编写函数void fun(int *dp,int n,int upordown),其功能是,找出dp所指数组中的最小或最大值,并与其第1个元素交换。形参n为元素的个数,形参upordown为查找标志:值为0时找最小值;值为1时找最大值。

注意:部分源程序在文件PROG1.C中。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。

#include <stdio.h>
#include <stdlib.h>
#define N 10
#pragma warning (disable:4996)
void NONO(FILE *fp, int pd[], int n);void fun (int *dp,int n,int upordown)
{int temp=0;int i=0;temp=*dp;if(upordown==0){for(i=1;i<n;i++){if(dp[i]<temp){dp[0]=dp[i];dp[i]=temp;temp=dp[0];}}}else if(/******found******/){for(/******found******/){if(/******found******/){/******found******//******found******//******found******/}}
}
*dp=temp;}void display(int pd[],int n)
{int i;for(i=0;i<n;i++)printf("%4d",pd[i]);printf("\n");
}
void main()
{int data[N],i,n=N;FILE *out ;out = fopen("out.dat","w") ;for(i=0;i<N;i++)data[i]=rand()%90+10;for(i=0;i<N-1;i++)fun(data+i,n-i,0);display(data,n);NONO(out, data, n);for(i=0;i<N;i++)data[i]=rand()%90+10;for(i=0;i<N-1;i++)fun(data+i,n-i,1);display(data,n);NONO(out, data, n);fclose(out);
}
void NONO(FILE *fp, int pd[], int n)
{int i;for(i=0;i<n;i++)fprintf(fp, "%4d", pd[i]);fprintf(fp, "\n");}
  1. 正确答案: upordown==1
  2. 正确答案: i=1;i<n;i++
  3. 正确答案: dp[i]>temp
  4. 正确答案: dp[0]=dp[i];
  5. 正确答案: dp[i]=temp;
  6. 正确答案: temp=dp[0];
  • 函数定义:void fun(int *dp, int n, int upordown) { /* ... */ } 函数 fun 接收一个整型指针 dp,表示数组的首地址,整数 n 表示数组元素的个数,整数 upordown 表示查找标志,值为0时找最小值,值为1时找最大值。

  • 局部变量声明:int temp = 0; int i = 0; 在函数内部声明了两个整型变量 tempitemp 用于保存当前数组元素的值,i 用于循环计数。

  • 初始化 temp:temp = *dp;temp 初始化为数组的第一个元素的值。

  • 查找最小值的逻辑:

    if (upordown == 0)
    {for (i = 1; i < n; i++){if (dp[i] < temp){dp[0] = dp[i];dp[i] = temp;temp = dp[0];}}
    }
    
    • 如果upordown 为0,表示查找最小值。在循环中,如果当前元素小于 temp,则交换它们,并更新 temp 的值。
  • 查找最大值的逻辑:

    else if (upordown == 1)
    {for (i = 1; i < n; i++){if (dp[i] > temp){dp[0] = dp[i];dp[i] = temp;temp = dp[0];}}
    }
    
    • 如果 upordown 为1,表示查找最大值。在循环中,如果当前元素大于 temp,则交换它们,并更新 temp 的值。
  • 将最小或最大值赋给第一个元素:*dp = temp;最终,将最小或最大值赋给数组的第一个元素。

  • 主函数中的调用和输出:

    for (i = 0; i < N - 1; i++)fun(data + i, n - i, 0);display(data, n);for (i = 0; i < N; i++)data[i] = rand() % 90 + 10;for (i = 0; i < N - 1; i++)fun(data + i, n - i, 1);display(data, n);
    
    • 主函数通过调用 fun 函数两次,一次查找最小值,一次查找最大值,然后输出结果。这样可以看到数组中最小值和最大值的位置发生了交换。

相关文章:

【C语言】详解计算机二级c语言程序题

文章目录 前言资料相关程序题 一&#xff08;字符串&#xff09;程序题 二&#xff08;数组&#xff09;程序题 三&#xff08;基础&#xff09;程序题 四&#xff08;结构体&#xff09;程序题 五&#xff08;结构体&#xff09;程序题 六&#xff08;基础&#xff09; 前言 …...

限流算法

下面对常见的限流算法进行讨论。目前&#xff0c;常用的限流算法主要有三种&#xff1a;计数器法、滑动窗口算法、漏桶算法和令牌桶算法。下面分别介绍其原理。 1. 计数器法 计数器法是通过计数对到来的请求进行选择性处理。如系统限制一秒内最多有X个请求&#xff0c;则在该…...

备战蓝桥杯 Day10(背包dp)

01背包问题 1267&#xff1a;【例9.11】01背包问题 【题目描述】 一个旅行者有一个最多能装 M&#xfffd; 公斤的背包&#xff0c;现在有 n&#xfffd; 件物品&#xff0c;它们的重量分别是W1&#xff0c;W2&#xff0c;...,Wn&#xfffd;1&#xff0c;&#xfffd;2&#…...

Sora 使用教程,新手小白可用

Sora 使用教程&#xff0c;新手小白可用 参考文章&#xff1a;Sora 使用教程&#xff0c;OpenAI 的文生视频模型 为了在激烈的行业竞争中保持领先地位&#xff0c;OpenAI 在 2024 年 2 月 15 日发布了其革命性的文本至视频转换模型——Sora。这个先进的工具能够将文本描述转化…...

【洛谷千题详解】P1031 均分纸牌

目录 题目描述 思路点拨 AC代码 题目描述 题目网址&#xff1a;[NOIP2002 提高组] 均分纸牌 - 洛谷 有 N 堆纸牌&#xff0c;编号分别为 1,2,……,N。每堆上有若干张&#xff0c;但纸牌总数必为 N 的倍数。可以在任一堆上取若干张纸牌&#xff0c;然后移动。 移牌规则为&a…...

基于文本提示和语义分割的快速抠图

基于文本提示和语义分割的快速抠图 1. 介绍2. 效果展示3. 安装模型4. 命令行调用5. 代码调用5.1 模型加载5.2 可视化函数定义5.3 图像语义分割 6. 参考资料7. 结语服务 1. 介绍 传统的图像语义分割模型通常固定类别进行分割&#xff0c;而基于文本提示的语义分割模型则具有更高…...

什么是媒体发稿?发稿媒体分类及发稿流程

传媒如春雨&#xff0c;润物细无声&#xff0c;大家好&#xff0c;我是51媒体网胡老师。 媒体发稿是一种企业推广和宣传的手段&#xff0c;通过媒体渠道传递企业信息和形象。 媒体发稿的含义在于&#xff0c;当企业有新闻、事件或其他消息需要对外公布时&#xff0c;可以选择…...

安全测试自学手册之软件安全测试基础

安全测试的概念 定义&#xff1a;指有关验证应用程序的安全等级和识别潜在安全性缺陷的过程。】 应用软件的安全性测试&#xff1a;软件自身设计中存在的安全隐患&#xff0c;并检查软件对非法入侵的防御能力。系统级别的安全性测试&#xff1a;确保只有具备系统平台访问权限…...

【LeetCode】升级打怪之路 Day 04:链表 part 2

今日题目&#xff1a; 24. 两两交换链表中的节点19. 删除链表的倒数第 N 个结点160. 相交链表142. 环形链表 II 目录 LeetCode 24. 两两交换链表中的节点 【易错】LeetCode 19. 删除链表的倒数第 N 个结点 【还行】LeetCode 160. 相交链表&#xff08;两个链表是否相交&#xf…...

JAVA编程题系列——涵盖几乎所有java内容

自己定义一个类&#xff0c;有static属性和构造方法&#xff0c;有构造方法重载&#xff0c;有其他方法&#xff08;方法有对String类型操作&#xff09; public class MyClass {// 静态属性public static String staticProperty "Static Property";// 成员变量priv…...

【Android12】Monkey压力测试源码执行流程分析

Monkey压力测试源码执行流程分析 Monkey是Android提供的用于应用程序自动化测试、压力测试的测试工具。 其源码路径(Android12)位于 /development/cmds/monkey/部署形式为Java Binary # development/cmds/monkey/Android.bp // Copyright 2008 The Android Open Source Proj…...

Java架构师之路八、安全技术:Web安全、网络安全、系统安全、数据安全等

目录 Web安全&#xff1a; 网络安全&#xff1a; 系统安全&#xff1a; 数据安全&#xff1a; Java架构师之路七、大数据&#xff1a;Hadoop、Spark、Hive、HBase、Kafka等-CSDN博客Java架构师之路九、设计模式&#xff1a;常见的设计模式&#xff0c;如单例模式、工厂模式…...

Codeforces Round 240 (Div. 1) C. Mashmokh and Reverse Operation(分治+逆序对)

原题链接&#xff1a;C. Mashmokh and Reverse Operation 题目大意&#xff1a; 给出一个长度为 2 n 2^{n} 2n 的正整数数组 a a a &#xff0c;再给出 m m m 次操作。 每次操作给出一个数字 q q q &#xff0c;把数组分为 2 n − q 2^{n-q} 2n−q 个长度为 2 q 2^{q} 2…...

SpringBoot源码解读与原理分析(三十二)SpringBoot整合JDBC(一)JDBC组件的自动装配

文章目录 前言第10章 SpringBoot整合JDBC10.1 SpringBoot整合JDBC的项目搭建10.1.1 初始化数据库10.1.2 整合项目10.1.2.1 导入JDBC和MySQL驱动依赖10.1.2.2 配置数据源 10.1.3 编写业务代码10.1.3.1 编写与t_user表对应的实体类User10.1.3.2 编写Dao层代码10.1.3.3 编写Servic…...

petalinux_zynq7 驱动DAC以及ADC模块之五:nodejs+vue3实现web网页波形显示

前文&#xff1a; petalinux_zynq7 C语言驱动DAC以及ADC模块之一&#xff1a;建立IPhttps://blog.csdn.net/qq_27158179/article/details/136234296petalinux_zynq7 C语言驱动DAC以及ADC模块之二&#xff1a;petalinuxhttps://blog.csdn.net/qq_27158179/article/details/1362…...

Android java中内部类的使用

一.成员内部类 实验1&#xff1a;成员内部类 class Outer {private int a 10;class Inner {public void printInfo(){System.out.println("a "a);}}}public class InnerDemo {public static void main(String args[]) {Outer o new Outer();Outer.Inner i o.new…...

llm的inference(二)

文章目录 Tokenizer分词1.单词分词法2.单字符分词法3.子词分词法BPE(字节对编码&#xff0c;Byte Pair Encoding)WordPieceUnigram Language Model(ULM) embedding的本质推理时的一些指标参考链接 Tokenizer 在使用模型前&#xff0c;都需要将sequence过一遍Tokenizer&#xf…...

pytorch -- torch.nn.Module

基础 torch.nn 是 PyTorch 中用于构建神经网络的模块。nn.Module包含网络各层的定义及forward方法。 在用户自定义神经网络时&#xff0c;需要继承自nn.Module类。通过继承 nn.Module 类&#xff0c;您可以创建自己的神经网络模型&#xff0c;并定义模型的结构和操作。 torch.n…...

Microsoft Edge 越用越慢、超级卡顿?网页B站播放卡顿?

记录10个小妙招 Microsoft Edge 启动缓慢、菜单导航卡顿、浏览响应沉闷&#xff1f;这些情况可能是由于系统资源不足或浏览器没及时更新引起的。接下来&#xff0c;我们将介绍 10 种简单的方法&#xff0c;让 Edge 浏览器的速度重新起飞。 基础检查与问题解决 如果 Microsoft…...

XGB-9: 分类数据

从1.5版本开始&#xff0c;XGBoost Python包为公共测试提供了对分类数据的实验性支持。对于数值数据&#xff0c;切分条件被定义为 v a l u e < t h r e s h o l d value < threshold value<threshold &#xff0c;而对于分类数据&#xff0c;切分的定义取决于是否使用…...

FreeRTOS学习第8篇--同步和互斥操作引子

目录 FreeRTOS学习第8篇--同步和互斥操作引子同步和互斥概念实现同步和互斥的机制PrintTask_Task任务相关代码片段CalcTask_Task任务相关代码片段实验现象本文中使用的测试工程 FreeRTOS学习第8篇–同步和互斥操作引子 本文目标&#xff1a;学习与使用FreeRTOS中的同步和互斥操…...

c++STL容器的使用(vector, list, map, set等),c++STL算法的理解与使用(sort, find, binary_search等)

cSTL容器的使用&#xff08;vector, list, map, set等&#xff09; 在C的STL&#xff08;Standard Template Library&#xff09;中&#xff0c;容器是重要的一部分&#xff0c;它们提供了各种数据结构来存储和管理数据。以下是一些常见的STL容器及其使用方法的简要说明&#x…...

选择VR全景行业,需要了解哪些内容?

近年来&#xff0c;随着虚拟现实、增强现实等技术的持续发展&#xff0c;VR全景消费市场得以稳步扩张。其次&#xff0c;元宇宙行业的高速发展&#xff0c;也在进一步拉动VR全景技术的持续进步&#xff0c;带动VR产业的高质量发展。作为一种战略性的新兴产业&#xff0c;国家和…...

830. 单调栈

Problem: 830. 单调栈 文章目录 思路解题方法复杂度Code 思路 这是一个单调栈的问题。单调栈是一种特殊的栈结构&#xff0c;它的特点是栈中的元素保持单调性。在这个问题中&#xff0c;我们需要找到每个元素左边第一个比它小的元素&#xff0c;这就需要使用到单调递增栈。 我们…...

H5 个人引导页官网型源码

H5 个人引导页官网型源码 源码介绍&#xff1a;源码无后台、无数据库&#xff0c;H5自检测适应、无加密&#xff0c;直接修改可用。 源码含有多选项&#xff0c;多功能。可展示自己站点、团队站点。手机电脑双端。 下载地址&#xff1a; https://www.changyouzuhao.cn/1434.…...

【Linux】部署前后端分离项目---(Nginx自启,负载均衡)

目录 前言 一 Nginx&#xff08;自启动&#xff09; 2.1 Nginx的安装 2.2 设置自启动Nginx 二 Nginx负载均衡tomcat 2.1 准备两个tomcat 2.1.1 复制tomcat 2.1.2 修改server.xml文件 2.1.3 开放端口 2.2 Nginx配置 2.2.1 修改nginx.conf文件 2.2.2 重启Nginx服务 2…...

WPF Style样式设置

1.本window设置样式 <Window x:Class"WPF_Study.MainWindow"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x"http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d"http://schemas.microsoft.com/expressi…...

【STM32】软件SPI读写W25Q64芯片

目录 W25Q64模块 W25Q64芯片简介 硬件电路 W25Q64框图 Flash操作注意事项 状态寄存器 ​编辑 指令集 INSTRUCTIONS​编辑 ​编辑 SPI读写W25Q64代码 硬件接线图 MySPI.c MySPI.h W25Q64 W25Q64.c W25Q64.h W25Q64_Ins.h main.c 测试 SPI通信&#xff08;W25…...

普通中小学校管理信息系统V1.1

普通中小学校管理信息系统 Ordinary Primary and Secondary Schools Management Information System 普通中小学校管理信息系统 Ordinary Primary and Secondary Schools Management Information System...

中国水果采摘机器人行业市场研究及发展趋势分析报告

全版价格&#xff1a;壹捌零零 报告版本&#xff1a;下单后会更新至最新版本 交货时间&#xff1a;1-2天 第一章 2016-2026年中国水果采摘机器人行业总概 1.1 中国水果采摘机器人行业发展概述 机器人技术的发展是一个国家高科技水平和工业自动化程度的重要标志和体现。机器…...

Linux多进程与信号

在多进程的服务程序中&#xff0c;如果子进程收到退出信号&#xff0c;子进程自行退出。如果父进程收到退出信号&#xff0c;应该先向全部的子进程发送退出信号&#xff0c;然后自己再退出。 演示demo程序 #include <iostream> // 包含输入输出流库&#xff0c;用于输…...

Self-attention与Word2Vec

Self-attention&#xff08;自注意力&#xff09;和 Word2Vec 是两种不同的词嵌入技术&#xff0c;用于将单词映射到低维向量空间。它们之间的区别&#xff1a; Word2Vec&#xff1a; Word2Vec 是一种传统的词嵌入&#xff08;word embedding&#xff09;方法&#xff0c;旨在为…...

【Flutter/Android】运行到安卓手机上一直卡在 Running Gradle task ‘assembleDebug‘... 的终极解决办法

方法步骤简要 查看你的Flutter项目需要什么版本的 Gradle 插件&#xff1a; 下载这个插件&#xff1a; 方法一&#xff1a;浏览器输入&#xff1a;https://services.gradle.org/distributions/gradle-7.6.3-all.zip 方法二&#xff1a;去Gradle官网找对应的版本&#xff1a;h…...

医疗实施-客户需求分析

在我的日常系统实施过程中&#xff0c;总会遇到不同角色的客户提出不同类别的需求。有的需求&#xff0c;客户目的想提高操作便携&#xff0c;但会对系统稳定性存在风险&#xff0c;应该拒掉。有些需求紧急而且影响重大&#xff0c;应该紧急处理。有些需求可以做&#xff0c;但…...

调度服务看门狗配置

查看当前服务器相关的sqlserver服务 在任务栏右键&#xff0c;选择点击启动任务管理器 依次点击&#xff0c;打开服务 找到sqlserver 相关的服务&#xff0c; 确认这些服务是启动状态 将相关服务在看门狗中进行配置 选择调度服务&#xff0c;双击打开 根据上面找的服务进行勾…...

AI时代 编程高手的秘密武器:世界顶级大学推荐的计算机教材

文章目录 01 《深入理解计算机系统》02 《算法导论》03 《计算机程序的构造和解释》04 《数据库系统概念》05 《计算机组成与设计&#xff1a;硬件/软件接口》06 《离散数学及其应用》07 《组合数学》08《斯坦福算法博弈论二十讲》 清华、北大、MIT、CMU、斯坦福的学霸们在新学…...

【数据结构和算法初阶(c语言)】数据结构前言,初识数据结构(给你一个选择学习数据结构和算法的理由)

1.何为数据结构 数据结构(Data Structure)是计算机存储、组织数据的方式&#xff0c;指相互之间存在一种或多种特定关系的 数据元素的集合。本质来讲就是在内存中去管理数据方式比如我们的增删查改。在内存中管理数据的方式有很多种&#xff08;比如数组结构、链式结构、树型结…...

LeetCode 0235.二叉搜索树的最近公共祖先:用搜索树性质(不遍历全部节点)

【LetMeFly】235.二叉搜索树的最近公共祖先&#xff1a;用搜索树性质&#xff08;不遍历全部节点&#xff09; 力扣题目链接&#xff1a;https://leetcode.cn/problems/lowest-common-ancestor-of-a-binary-search-tree/ 给定一个二叉搜索树, 找到该树中两个指定节点的最近公…...

【Prometheus】概念和工作原理介绍

目录 一、概述 1.1 prometheus简介 1.2 prometheus特点 1.3 prometheus架构图 1.4 prometheus组件介绍 1、Prometheus Server 2、Client Library 3、pushgateway 4、Exporters 5、Service Discovery 6、Alertmanager 7、grafana 1.5 Prometheus 数据流向 1.6 Pro…...

四川易点慧电子商务有限公司抖音小店:可靠之选,购物新体验

在当今这个网络购物日益盛行的时代&#xff0c;选择一家可靠的电商平台成为了消费者最为关心的问题之一。四川易点慧电子商务有限公司抖音小店作为新兴的电商力量&#xff0c;凭借其独特的魅力和优势&#xff0c;正逐渐成为众多消费者心中的可靠之选。 易点慧电子商务有限公司在…...

SpringBoot自带的tomcat的最大连接数和最大的并发数

先说结果&#xff1a;springboot自带的tomcat的最大并发数是200&#xff0c; 最大连接数是&#xff1a;max-connectionsaccept-count的值 再说一下和连接数相关的几个配置&#xff1a; 以下都是默认值&#xff1a; server.tomcat.threads.min-spare10 server.tomcat.threa…...

TLS1.2抓包解析

1.TLS1.2记录层消息解析 Transport Layer SecurityTLSv1.2 Record Layer: Handshake Protocol: Client HelloContent Type: Handshake (22)Version: TLS 1.0 (0x0301)Length: 253Content Type&#xff1a;消息类型&#xff0c;1个字节。 i 0Version&#xff1a;协议版本&…...

使用两个队列实现栈

在计算机科学中&#xff0c;栈是一种数据结构&#xff0c;它遵循后进先出&#xff08;LIFO&#xff09;的原则。这意味着最后一个被添加到栈的元素将是第一个被移除的元素。然而&#xff0c;Java的标准库并没有提供栈的实现&#xff0c;但我们可以使用两个队列来模拟一个栈的行…...

通过ffmpeg实现视频背景色替换

最近遇到一个需求&#xff0c;希望可以将素材视频的绿幕背景替换为指定的颜色&#xff0c;然后通过裁剪&#xff0c;拼接等处理制作一个新的视频。所以替换背景色成为了重要的一环&#xff0c;看能否通过ffmpeg来实现。通过一番搜索尝试&#xff0c;发现方案可行。下面我整理一…...

后轮位置反馈控制与算法仿真实现

文章目录 1. 后轮反馈控制2. 算法原理3. 算法和仿真实现 1. 后轮反馈控制 后轮反馈控制&#xff08;Rear wheel feedback&#xff09;算法是利用后轮中心的跟踪偏差来进行转向控制量计算的方法&#xff0c;属于Frenet坐标系的一个应用。通过选择合适的李雅普诺夫函数设计控制率…...

实战 vue3 使用百度编辑器ueditor

前言 在开发项目由于需求vue自带对编辑器不能满足使用&#xff0c;所以改为百度编辑器&#xff0c;但是在网上搜索发现都讲得非常乱&#xff0c;所以写一篇使用流程的文章 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面案例可供参考 一、下载ueditor编辑器 一个“…...

N种方法解决1(CTF)

这里遇到的问题&#xff1a;一开始采用的base64解码平台有问题&#xff1b;默认解密出的格式为GBK格式&#xff1b;直接复制粘贴发现无法还原图片&#xff1b;又尝试了其他编码的&#xff1b;发现只有hex格式可以保证图片正常还原&#xff1b; 图片是以二进制存储的&#xff1…...

Istio实战:Istio Kiali部署与验证

目录 前言一、Istio安装小插曲 注意事项 二、Kiali安装三、Istio测试参考资料 前言 前几天我就开始捣腾Istio。前几天在执行istioctl install --set profiledemo -y 的时候老是在第二步就报错了&#xff0c;开始我用的istio版本是1.6.8。 后面查看k8s与istio的版本对应关系后发…...

ASPxGridView中使用PopupEditForm表单字段联动填充

c#中devexpress的控件ASPxGridView中使用PopupEditForm表单字段联动填充 //选择项目名称&#xff0c;自动填充项目编号 <Columns><dx:GridViewDataTextColumn FieldName"id" ReadOnly"True" VisibleIndex"0" Visible"False"…...

基于Pytorch的猫狗图片分类【深度学习CNN】

猫狗分类来源于Kaggle上的一个入门竞赛——Dogs vs Cats。为了加深对CNN的理解&#xff0c;基于Pytorch复现了LeNet,AlexNet,ResNet等经典CNN模型&#xff0c;源代码放在GitHub上&#xff0c;地址传送点击此处。项目大纲如下&#xff1a; 文章目录 一、问题描述二、数据集处理…...