【C语言】循环语句详解

✨个人主页: Anmia.
🎉所属专栏: C Language

🎃操作环境: Visual Studio 2019 版本

 

目录

 1.什么是循环结构?

2.while循环

while流程图

while语句中的break和continue

break 

continue

 3.for循环

for流程图

for循环中的break和continue

break

continue 

for语句的循环控制变量

一些for循环的变种

do...while()循环

do...while()循环流程图

do...while对比while,for有什么特殊?

do while循环中的break和continue

break 

continue 

练习

练习1

练习2

 练习3

练习4

练习5

练习6

后言​​​​​​​


 1.什么是循环结构?

用顺序结构和选择结构可以解决简单的,不重复的问题,但在日常生活中或者是在应用程序中,许多问题是需要反复处理执行的。

  • 问题1:分别统计全班50个学生的平均成绩。
  • 问题2:求30个整数的和。

要处理以上问题,最原始的方法是分别编写若干个相同或者相似的语句或者程序段来进行处理,这种方法工作量大,程序长,重复,难以阅读和维护。

循环结构又称为重复结构,利用循环结构可以方便的处理这种需要重复处理的问题。大多数应用程序都是包含循环结构。

C语言给我们提供了三种循环语句:

  • while
  • do...while
  • for

2.while循环

我们已经掌握了,if语句:

if(条件)语句;

当条件满足的情况下,if语句后的语句执行,否则不执行。
但是这个语句只会执行一次。
由于我们发现生活中很多的实际的例子是:同一件事情我们需要完成很多次。
那我们怎么做呢?
C语言中给我们引入了: while 语句,可以实现循环。

while(表达式)
循环语句;

while流程图


 

比如我们实现:
在屏幕上打印1-10的数字。

#include <stdio.h>
int main()
{int i = 1;while(i<=10){printf("%d ", i);i = i+1;}return 0;
}

以 i 作为是否执行while循环的条件,我们此时i =1 满足 i<=10 这个循环条件,所以加入whilex循环。先打印1,然后i+1变成2,2再和循环条件i<=10进行判断,满足则继续执行循环体,直到i=11不满足i<=10,退出循环体,结束循环。运行结果如下

上面的代码已经帮我了解了 while 语句的基本语法,那我们再了解一下:


 

while语句中的break和continue

break 

#include <stdio.h>
int main()
{int i = 1;while(i<=10){if(i == 5)break;printf("%d ", i);i = i+1;}return 0;
}

这里的输出结果是什么?

答案如图。

看运行结果不难看出,在i 加到5时,在进行if循环判断时,if条件成立,执行break语句。直接跳出了当前的while循环,不再执行后面的循环语句。

通过之前学习的switch中的break,似乎效果一致,即跳出当前的循环语句/switch语句。

  • 总结:
  • break在while循环中的作用:
  • 其实在循环中只要遇到break,就停止后期的所有的循环,直接终止循环。
  • 所以:while中的break是用于永久终止循环的。

 

continue

#include <stdio.h>
int main()
{int i = 1;while(i<=10){i = i+1;if(i == 5)continue;printf("%d ", i);}return 0;
}

这段代码的运行结果又是什么呢?

答案如图。

看运行结果不难看出,进入循环i先+1后打印,所以没有打印1。当i+1=5时进入if中的语句,执行continue,我们发现没打印5,但是打印了后面的6 7 8 9 10 11。

  • 没打印5的原因:因为continue是结束本次循环后面的语句,因此在Continue执行后,后面的printf被跳过了,直接跳回到i=i+1,继续循环往复。
  • 打印了11的原因:因为i=10仍然是满足条件i<=10后还会执行循环体。
  • 总结:
  • continue在while循环中的作用就是:
  • continue是用于终止本次循环的,也就是本次循环中continue后边的代码不会再执行,
  • 而是直接跳转到while语句的判断部分。进行下一次循环的入口判断。

下面再看两段代码,分别是什么意思?

#include <stdio.h>
int main()
{int ch = 0;while ((ch = getchar()) != EOF)putchar(ch);return 0;
}

getchar()  - 获取(输入)一个字符
getchar 读取字符成功时,返回字符的ASCLL码值
读取失败时 或者 遇到文件末尾时就返回EOF

 windows环境Ctrl + z getchar返回 EOF

详细见:

【C语言】EOF搭配while循环来控制scanf输入的次数_Anmia.的博客-CSDN博客

#include <stdio.h>
int main()
{char ch = '\0';while ((ch = getchar()) != EOF){if (ch < ‘0’ || ch > ‘9’)continue;putchar(ch);}return 0;
}

这个代码的作用是:只打印数字字符,跳过其他字符的。


 3.for循环

我们已经知道了while循环,但是我们为什么还要一个for循环呢?
首先来看看for循环的语法:

for(表达式1; 表达式2; 表达式3)循环语句;
  • 表达式1:为初始化部分,用于初始化循环变量的。
  • 表达式2:为条件判断部分,用于判断循环时候终止。
  • 表达式3:为调整部分,用于循环条件的调整。

例子1:

使用for循环 在屏幕上打印1-10的数字。

#include <stdio.h>
int main()
{int i = 0;//for(i=1/*初始化*/; i<=10/*判断部分*/; i++/*调整部分*/)for(i=1; i<=10; i++){printf("%d ", i);}return 0;
}

 

for流程图

现在我们对比一下for循环和while循环。

//实现相同的功能,使用while
int i = 0;
i=1;//初始化部分
while(i<=10)//判断部分
{printf("hehe\n");i = i+1;//调整部分
}//实现相同的功能,使用for
for(i=1; i<=10; i++)
{printf("hehe\n");
}

可以发现在while循环中依然存在循环的三个必须条件,但是由于风格的问题使得三个部分很可能偏离较
远,这样
查找修改就不够集中和方便。所以,for循环的风格更胜一筹;for循环使用的频率也最高。


for循环中的break和continue

break

我们发现在for循环中也可以出现break和continue,他们的意义和在while循环中是一样的。

但是还是有些差异:

#include <stdio.h>
int main()
{int i = 0;for(i=1; i<=10; i++){if(i == 5)break;printf("%d ",i);}return 0;
}

continue 

#include <stdio.h>
int main()
{int i = 0;for(i=1; i<=10; i++){if(i == 5)continue;printf("%d ",i);}return 0;
}

通过和while的代码对比,相信不难区分它们的写法


for语句的循环控制变量

建议:
1. 不可在for 循环体内修改循环变量,防止 for 循环失去控制。
2. 建议for语句的循环控制变量的取值采用“前闭后开区间”写法。

int i = 0;
//前闭后开的写法
for(i=0; i<10; i++)
{}//两边都是闭区间
for(i=0; i<=9; i++)
{}

一些for循环的变种

#include <stdio.h>
int main()
{for (;;){printf("hehe\n");}
}

for循环中的初始化部分,判断部分,调整部分是可以省略的,但是不建议初学时省略,容易导致问题。 


这里打印多少个hehe?

#include <stdio.h>
int main()
{int i = 0;int j = 0;for (i = 0; i < 10; i++){for (j = 0; j < 10; j++){printf("hehe\n");}}return 0;
}

答案是100个,这种形式是for的嵌套。

代码逻辑:

i=0--> i<10成立进入外层for --> j=0 --> j<10成立进入内层for -->打印hehe\n --> j++后 j=2       --> j<10成立继续循环........直到 j=10,j<10不成立跳出内层for---> i++后i=2 --> i<10成立再次进入外层for......直到i=10,j<10不成立跳出外层for,for嵌套结束。

  • 简单点看

无非就是满足for循环条件就进入循环,只是外层for循环体中又有一个内层for而已。


如果省略掉初始化部分,这里打印多少个hehe?

#include <stdio.h>
int main()
{int i = 0;int j = 0;for (; i < 10; i++){for (; j < 10; j++){printf("hehe\n");}}return 0;
}​

答案是10个,对比上一题,为什么少打印了那么多?主要问题出现在内层初始化部分被省略了,当j++第一次到j=10内层条件不满足,跳出内层循环到i++,i=2时i<10是满足的,会执行外层for的循环体,可是问题就是j之前已经++到10了,内层for有没有初始化部分,会直接检查条件部分是否满足,但j此时是10了,就j<10这个条件就不满足了,因此不会再执行内层for循环。


使用多余一个变量控制循环

int x, y;for (x = 0, y = 0; x<2 && y<5; ++x, y++){printf("hehe\n");}

例题1:

请问下面循环要循环多少次?

#include <stdio.h>
int main()
{int i = 0;int k = 0;for (i = 0, k = 0; k = 0; i++, k++){k++;}return 0;
}

答案是0次,代码中存在一个错误的循环条件,导致循环无法正常终止。在循环条件 k = 0 中,应该使用相等运算符 == 而不是赋值运算符 =。


do...while()循环

  • 语法如下:
do
{循环语句;
}while(表达式);

do...while()循环流程图


do...while对比while,for有什么特殊?

循环至少执行一次,使用的场景有限,所以不是经常使用。以下是代码案例。

#include <stdio.h>
int main()
{int i = 10;do{printf("%d\n", i);}while(i<10);return 0;
}

do while循环中的break和continue

break 

#include <stdio.h>
int main()
{int i = 10;do{if (5 == i)break;printf("%d\n", i);} while (i < 10);return 0;
}

以上代码,单看i=10肯定是不满足i<10这个循环条件的,但由于do...while循环的特性,它不论循环条件是否成立,都会先执行一次循环体再进行判断。所以上面代码结果是只输出了10。


continue 

那这段代码的结果呢?

#include <stdio.h>
int main()
{int i = 10;do{if (5 == i)continue;printf("%d\n", i);} while (i < 10);return 0;
}

答案也是只输出一个10,原因同上。


练习

练习1

计算 n的阶乘。

#include <stdio.h>int main() {int n;unsigned long long factorial = 1;printf("请输入一个非负整数:");scanf("%d", &n);if (n < 0) {printf("输入的数必须是非负整数。\n");}else {for (int i = 1; i <= n; i++) {factorial *= i;}printf("%d 的阶乘是 %llu\n", n, factorial);}return 0;
}

练习2

计算n的阶乘和。

#include <stdio.h>int main() {int n;unsigned long long factorialSum = 0;printf("请输入一个非负整数:");scanf("%d", &n);if (n < 0) {printf("输入的数必须是非负整数。\n");}else {for (int i = 1; i <= n; ++i) {unsigned long long factorial = 1;for (int j = 1; j <= i; ++j) {factorial *= j;}factorialSum += factorial;}printf("从1到%d的阶乘和是 %llu\n", n, factorialSum);}return 0;
}

这段代码首先要求用户输入一个非负整数,并将其存储在变量 n 中。然后,使用两个嵌套的 for 循环来计算从 1 到 n 的所有整数的阶乘,并将每个阶乘的结果累加到 factorialSum 变量中。最后,使用 printf 函数将结果输出到屏幕上。


 练习3

用二分查找在一个有序数组中查找具体的某个数字n

int main()
{int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };int sz = sizeof(arr) / sizeof(arr[0]);int left = 0;//左下标int right = sz - 1;//右下标int num = 0;int flag = 0;scanf("%d", &num);while (left <= right){int mid = (left + right) / 2;//(左下标+右下标)/2if (arr[mid] < num){left = mid + 1;}else if (arr[mid] > num){right = mid - 1;}else{printf("找到了,数字%d的下标是:%d\n", num, mid);flag = 1;break;}}if (flag == 0){printf("没找到!");}return 0;
}

这段代码使用二分查找算法在给定的有序数组中查找一个特定的数字。

首先,定义一个整型数组 arr,并初始化为 {1,2,3,4,5,6,7,8,9,10}。然后,计算数组的大小 sz,即数组中元素的个数。

接下来,定义两个变量 left 和 right 分别表示数组的左下标和右下标。初始时,left 设为 0,right 设为 sz - 1

然后,通过用户输入获取一个数字 num

接下来,使用一个循环来执行二分查找。循环条件是 left <= right,即左下标小于等于右下标。在每次循环中,计算中间下标 mid,即 (left + right) / 2

然后,根据中间元素的值与目标数字 num 的大小关系,更新左下标和右下标。如果中间元素小于 num,则将左下标 left 更新为 mid + 1;如果中间元素大于 num,则将右下标 right 更新为 mid - 1

如果中间元素等于 num,则找到了目标数字,输出找到的消息,并将标志变量 flag 设为 1,然后使用 break 语句跳出循环。

如果循环结束后 flag 仍为 0,表示未找到目标数字,输出未找到的消息。

最后,返回 0 表示程序执行完毕。

这段代码适用于在有序数组中查找特定数字的场景。如果数组是无序的,二分查找算法将不适用,需要使用其他查找算法。


练习4

 编写代码,演示多个字符从两端移动,向中间汇聚

#include <string.h>
#include <windows.h>
int main()
{char arr1[] = "Hello World!!!";char arr2[] = "**************";int left = 0;//左下标int right = strlen(arr2) - 1;//右下标//-1是因为数组下标从0开始while (left <= right){arr2[left] = arr1[left];arr2[right] = arr1[right];printf("%s\n", arr2);Sleep(1000);//等待一秒system("cls");//清空屏幕left++;right--;}printf("%s\n", arr2);printf("%d\n", strlen(arr2));return 0;
}

这段代码使用两个字符数组 arr1 和 arr2 来模拟一个动态变化的字符串效果。

首先,定义一个字符数组 arr1 并初始化为 "Hello World!!!",定义另一个字符数组 arr2 并初始化为 "**************",长度与 arr1 相同。

接下来,定义两个变量 left 和 right 分别表示 arr2 的左下标和右下标。初始时,left 设为 0,right 设为 strlen(arr2) - 1,其中 strlen(arr2) 函数用于获取 arr2 的长度。

然后,使用一个循环来依次将 arr1 中的字符赋值给 arr2 对应位置的字符,并在每次循环中输出 arr2 的内容。为了实现动态效果,使用 Sleep 函数暂停一秒钟,然后使用 system("cls") 函数清空屏幕。

循环结束后,输出最终的 arr2 的内容和长度。

最后,返回 0 表示程序执行完毕。

这段代码的目的是实现一个字符动画效果,将 arr1 中的字符逐渐替换 arr2 中的字符,并在每次替换后输出 arr2 的内容。通过循环中的延时和清空屏幕操作,实现了字符动态变化的效果。


练习5

编写代码实现,模拟用户登录情景,并且只能登录三次。(只允许输入三次密码,如果密码正确则提示登录成功,如果三次均输入错误,则退出程序。

#include <string.h>
#include <windows.h>
int main()
{int i;char password[20] = { 0 };for (i = 0; i < 3; i++){printf("请输入密码:>");scanf("%s", password);if (strcmp(password, "123456") == 0){printf("密码正确!\n");break;}else{printf("密码错误!\n");Sleep(1000);system("cls");}}if (i == 3){printf("三次输入错误,登录失败!");}return 0;
}

这段代码实现了一个简单的密码验证功能。

首先,定义一个整型变量 i,用于记录密码输入的次数。

然后,定义一个字符数组 password,长度为 20,并初始化为全零。

接下来,使用一个 for 循环,循环次数为 3,表示最多允许输入密码三次。

在每次循环中,使用 printf 函数提示用户输入密码,并使用 scanf 函数获取用户输入的密码,并将其存储在 password 数组中

然后,使用 strcmp 函数将用户输入的密码与预设的密码 "123456" 进行比较。如果两个密码相等,即返回值为 0,表示密码正确,输出密码正确的消息,并使用 break 语句跳出循环。

如果密码不正确,则输出密码错误的消息,使用 Sleep 函数暂停一秒钟,然后使用 system("cls") 函数清空屏幕,以便下一次输入密码。

循环结束后,判断变量 i 的值是否等于 3。如果等于 3,表示密码输入错误的次数已达到上限,输出登录失败的消息。

最后,返回 0 表示程序执行完毕。

这段代码的目的是实现一个简单的密码验证功能。用户可以最多输入三次密码,如果密码输入正确,则输出密码正确的消息并登录成功;如果密码输入错误,则输出密码错误的消息,并在每次错误后暂停一秒钟并清空屏幕,以便重新输入密码。如果连续三次输入都错误,则输出登录失败的消息。


练习6

猜数字游戏实现

#include <stdlib.h>//rand 和 srand需要
#include <time.h>	//time需要
void menu()
{printf("********************\n");printf("****  1.  play  ****\n");printf("****  0.  exit  ****\n");printf("********************\n");
}
void game()
{//1. 生成1-100随机数//rand函数,生成的是伪随机数,范围是0-RAND_MAX(32767);//rand函数需要用srand函数来设置随机数生成器int ret = rand() % 100 + 1;//%100-->(0~99)   +1 -->(1~100)   //2. 猜数字int guess = 0;while (1){printf("请猜数字:>");scanf("%d", &guess);if (guess < ret){printf("猜小了!\n");}else if(guess > ret){printf("猜大了!\n");}else{printf("猜对了!\n");break;}}}
int main()
{srand((unsigned int)time(NULL));//unsigned int 是因为srand函数的参数需要,所以要强制类型转化//NULL是因为time函数参数需要一个指针变量,所以我们可以用空指针代替。int input = 0;do{menu();printf("请输入:>");scanf("%d", &input);switch (input){case 1:game();break;case 0:printf("退出游戏\n");break;default:printf("输入错误,请重新输入!\n");break;}} while (input);return 0;
}

这段代码实现了一个猜数字游戏。游戏开始时,会显示一个菜单,让玩家选择是否开始游戏或退出游戏。

在 game() 函数中,首先使用 rand() 函数生成一个 1 到 100 之间的随机数,并将其赋值给变量 ret

然后,使用一个 while 循环,让玩家不断输入猜测的数字,直到猜对为止。

在每次循环中,玩家输入猜测的数字,并与随机数 ret 进行比较。

如果猜测的数字小于 ret,则输出 "猜小了"。

如果猜测的数字大于 ret,则输出 "猜大了"。

如果猜测的数字等于 ret,则输出 "猜对了",并使用 break 语句跳出循环。

在 main() 函数中,使用 srand() 函数设置随机数生成器的种子,以确保每次运行程序时生成的随机数不同。

然后,使用一个 do-while 循环,显示菜单并根据玩家的选择执行相应的操作。如果玩家输入的是 1,则调用 game() 函数开始游戏;如果玩家输入的是 0,则输出 "退出游戏" 并结束循环;如果玩家输入的是其他数字,则输出 "输入错误,请重新输入"。

循环条件是 input,当玩家输入 0 时,循环结束。

最后,返回 0 表示程序执行完毕。

这段代码的目的是实现一个简单的猜数字游戏。玩家根据提示输入猜测的数字,通过与随机生成的数字进行比较,判断猜测的数字是大了、小了还是猜对了,并给出相应的提示。玩家可以选择继续游戏或退出游戏。


后言

本篇较为详细的将了循环语句中的重点,以及6道测试题检测学习情况,对后面学习可以起到一定的理解帮助。希望可以得到支持,后面会持续输出各项详解。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/114071.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

进程Start

Linux中的命令解释器和Windows的程序管理器explorer.exe一样地位,都是在用户态下运行的进程 共享变量发生不同进程间的指令交错&#xff0c;就可能会数据出错 进程只作为除CPU之外系统资源的分配单位 CPU的分配单位是线程 每个进程都有自己的独立用户空间 内核空间是OS内核的…

PyCharm切换虚拟环境

PyCharm切换虚拟环境 为了满足不同任务需要不同版本的包&#xff0c;可以在Anaconda或者Miniconda创建多个虚拟环境文件夹&#xff0c;并在PyCharm下切换虚拟环境。 解决方案 1、打开Ananconda Prompt 2、创建自己的虚拟环境 格式&#xff1a;conda create -n 虚拟环境名字…

PSP - 蛋白质结构预测 OpenFold Multimer 模型训练参数与配置

欢迎关注我的CSDN&#xff1a;https://spike.blog.csdn.net/ 本文地址&#xff1a;https://spike.blog.csdn.net/article/details/132575709 OpenFold Multimer 是用于预测蛋白质多聚体结构的计算方法。基于OpenFold 的单体预测框架&#xff0c;利用深度学习技术&#xff0c;结…

dayjs格式转换成日期

目录 方法一&#xff1a; ​编辑方法二&#xff1a; 这个项目在筛选订单时间的时候是由前端进行筛选的&#xff0c;用的是adt-design-pro进行二开的&#xff0c;其中在用日期组件的时候遇到了一个问题&#xff0c;组件返回的是&#xff1a; 但是我需要的是年-月-日&#xff…

java八股文面试[数据库]——MySql聚簇索引和非聚簇索引区别

聚集索引和非聚集索引 聚集索引和非聚集索引的根本区别是表记录的排列顺序和与索引的排列顺序是否一致。 1、聚集索引 聚集索引表记录的排列顺序和索引的排列顺序一致&#xff08;以InnoDB聚集索引的主键索引来说&#xff0c;叶子节点中存储的就是行数据&#xff0c;行数据在…

LeetCode 面试题 02.04. 分割链表

文章目录 一、题目二、C# 题解 一、题目 给你一个链表的头节点 head 和一个特定值 x&#xff0c;请你对链表进行分隔&#xff0c;使得所有 小于 x 的节点都出现在 大于或等于 x 的节点之前。 你不需要 保留 每个分区中各节点的初始相对位置。 点击此处跳转题目。 示例 1&#…

c# 本地化中英文切换

区域 线程默认区域为当前计算机所选区域 设置当前区域&#xff1a; Thread.CurrentThread.CurrentCulture new CultureInfo(“zh-cn”); 获取当前区域&#xff1a; Console.WriteLine(Thread.CurrentThread.CurrentCulture.ToString()); 区域名称&#xff1a; “zh-cn” 中文…

Spooling的原理

脱机技术 程序猿先用纸带机把自己的程序数据输入到磁带中&#xff0c;这个输入的过程是由一台专门的外围控制机实现的。之后CPU直接从快速的磁带中读取想要的这些输入数据。输出也类似。 假脱机技术&#xff08;Spooling技术&#xff09; 即用软件的方式来模拟脱机技术。要…

python爬虫14:总结

python爬虫14&#xff1a;总结 前言 ​ python实现网络爬虫非常简单&#xff0c;只需要掌握一定的基础知识和一定的库使用技巧即可。本系列目标旨在梳理相关知识点&#xff0c;方便以后复习。 申明 ​ 本系列所涉及的代码仅用于个人研究与讨论&#xff0c;并不会对网站产生不好…

如何实现AI的矢量数据库

推荐&#xff1a;使用 NSDT场景编辑器 助你快速搭建3D应用场景 然而&#xff0c;人工智能模型有点像美食厨师。他们可以创造奇迹&#xff0c;但他们需要优质的成分。人工智能模型在大多数输入上都做得很好&#xff0c;但如果它们以最优化的格式接收输入&#xff0c;它们就会真正…

DNS指向别名还是IP

现在有一台服务器dbprod126&#xff0c;ip是172.22.100.4 现在有一个需求&#xff0c;需要在dns中对dbprod126建一个别名wondadb3r的记录&#xff0c;也就是ping wondadb3r的时候显示的是dbprod126的ip&#xff0c;目前有两​种方法&#xff0c;主要使用方法1指向别名&#xf…

【Docker】网络

文章目录 Docker 网络基础Docker网络管理Docker网络架构CNMLibnetwork驱动 常见的网络类型 Docker 网络管理命令docker network createdocker network inspectdocker network connectdocker network disconnectdocker network prunedocker network rmdocker network ls docker …

多线程网络实现在线聊天系统(详细源码)

这篇博客整理自韩顺平老师的多线程网络学习&#xff0c;在Java基础中最难的就是多线程以及网络编程了&#xff0c;如果不太熟悉的小伙伴可以跟着课程学习&#xff0c;韩老师讲得很详细&#xff0c;缺点就是太详细有点墨迹。实现后的效果是在一个类似命令行窗口进行聊天&#xf…

软件测试—测试用例的设计

软件测试—测试用例的设计 测试用例是什么&#xff1f; 首先&#xff0c;测试用例&#xff08;Test Case&#xff09;是为了实施测试而向被测试系统提供的一组集合。这组集合包括&#xff1a;测试环境、操作步骤、测试数据、预期结果等要素。 好的测试用例的特征 一个好的测试…

349. 两个数组的交集

题目来源&#xff1a;力扣 题目描述&#xff1a; 给定两个数组 nums1 和 nums2 &#xff0c;返回 它们的交集 。输出结果中的每个元素一定是 唯一 的。我们可以 不考虑输出结果的顺序 。 示例 1&#xff1a; 输入&#xff1a;nums1 [1,2,2,1], nums2 [2,2] 输出&#x…

jdbc235

概念&#xff1a;java database connectivity java数据库连接 java语言操作数据库 定义了一套操作所有关系型数据库的规则&#xff08;接口&#xff09; 本质&#xff1a;其实是官方公司定义了一套操作所有关系型数据库的规则&#xff0c;即接口。各个数据库厂商去实现这套接…

SSH远程连接macOS服务器:通过cpolar内网穿透技术实现远程访问的设置方法

文章目录 前言1. macOS打开远程登录2. 局域网内测试ssh远程3. 公网ssh远程连接macOS3.1 macOS安装配置cpolar3.2 获取ssh隧道公网地址3.3 测试公网ssh远程连接macOS 4. 配置公网固定TCP地址4.1 保留一个固定TCP端口地址4.2 配置固定TCP端口地址 5. 使用固定TCP端口地址ssh远程 …

联想电脑装系统无法按F9后无法从系统盘启动的解决方案

开机时按F9发现没有加载系统盘. 打开BIOS设置界面&#xff0c;调整设置如下: BOOT MODE: Legacy Support.允许legacy方式boot. BOOT PRIORITY: Legacy First. Legacy方式作为首选的boot方式. USB BOOT: ENABLED. 允许以usb方式boot. Legacy: 这里设置legacy boot的优先级,…

postgresql-日期函数

postgresql-日期函数 日期时间函数计算时间间隔获取时间中的信息截断日期/时间创建日期/时间获取系统时间CURRENT_DATE当前事务开始时间 时区转换 日期时间函数 PostgreSQL 提供了以下日期和时间运算的算术运算符。 计算时间间隔 age(timestamp, timestamp)函数用于计算两…

栈和队列(优先级队列)

一)删除字符串中所有相邻字符的重复项 1047. 删除字符串中的所有相邻重复项 - 力扣&#xff08;LeetCode&#xff09; 算法原理:栈结构模拟&#xff0c;只是需要遍历所有字符串中的字符&#xff0c;一次存放到栈里面即可&#xff0c;也是可以使用数组来模拟一个栈结构的: class…