C语言密码验证:3次机会解锁

用户登录密码验证

用字符数组实现密码验证;先提示用户输入密码,若错误,则允许重新输 入,单最多允许输入3次。若3次都输入错误,就结束程序;如果输入正确, 则显示"密码通过"。

#include <stdio.h>
#include <string.h>

int main()
{
char a[4] = {"123"};
char n[10];
int i = 0;
do {
printf("请输入密码:\n");
gets(n);

if (strcmp(n, a) == 0)
{
printf("密码通过\n");
break;
}
else
{
printf("密码错误!请重新输入\n");
printf("您还可以输入%d次",2-i);
}
i++;
} while (i<3);

return 0;
}

该程序预设了一个密码 "123"。运行后,它会提示用户输入密码。用户有最多三次尝试机会:

  • 如果输入的密码正确,程序会显示"密码通过"并立即结束。
  • 如果输入的密码错误,程序会提示错误,并告知用户还剩多少次尝试机会。
  • 如果三次都输入错误,循环结束,程序也随之结束。

#include <string.h>:引入字符串处理库。这是为了使用 **strcmp**函数来比较两个字符串是否相等。

一.主函数与变量定义

  • char a[4] = {"123"};:定义一个字符数组 a 并初始化为字符串 "123"。这个数组用来存储预设的正确密码 。数组大小为4,因为字符串 "123" 在内存中实际存储为 '1', '2', '3', '\0' (字符串结束符),共4个字节。
  • char n[10];:定义一个字符数组 n,用来存储用户输入的密码 。大小为10,意味着最多可以接收9个字符的密码(留一个位置给结束符 '\0')。
  • int i = 0;:定义一个整型变量 i 并初始化为0。它在这里充当计数器,记录用户已经尝试输入密码的次数。

二.密码验证循环

这里使用了 do-while 循环。它的特点是先执行一次循环体内的代码,然后再判断条件。这保证了用户至少会被提示输入一次密码。循环会一直执行,直到条件i<3不再满足(即 i 的值变为3)为止。

三.循环体内部逻辑

  • printf("请输入密码:\n");:在屏幕上打印提示信息,告诉用户该做什么。
  • gets(n);:从标准输入(键盘)读取一行文本,并将其存储到字符数组 n 中。

重要安全提示
gets() 函数非常不安全,因为它不检查输入的长度。如果用户输入的字符超过数组 n 的大小(10个字节),就会发生缓冲区溢出 ,可能覆盖掉程序中其他重要数据,导致程序崩溃或产生安全漏洞。在实际编程中,应始终使用 fgets(n, sizeof(n), stdin); 来替代 gets()

  • strcmp(n, a):这是 **string.h**库中的函数,用于比较字符串 n (用户输入) 和 a (正确密码)。
    • 如果两个字符串完全相同 ,函数返回 0
    • 如果不同,则返回一个非零值。
  • if (strcmp(n, a) == 0):判断密码是否正确。
  • printf("密码通过\n");:如果密码正确,打印成功信息。
  • break;:这是一个关键语句。它会立即跳出并终止 当前所在的整个 **do-while**循环。一旦密码正确,就不再需要后续的尝试了。
  • else:如果 if 的条件不满足(即密码错误),则执行这里的代码。
  • printf("密码错误!请重新输入\n");:提示用户密码输入错误。
  • printf("您还可以输入%d次",2-i);:动态计算并显示剩余的尝试次数。
    • 当**i=0** (第1次尝试),显示**2-0=2** 次。
    • i=1(第2次尝试),显示 **2-1=1**次。
    • 当**i=2**(第3次尝试),显示 **2-2=0**次。
  • i++;:在一次尝试(无论对错)结束后,将计数器 i 的值加1。然后程序会回到 while(i<3); 判断是否继续下一轮循环。
相关推荐
穿条秋裤到处跑2 小时前
每日一道leetcode(2026.03.30):判断通过操作能否让字符串相等 II
算法·leetcode
Q741_1472 小时前
每日一题 力扣 2840. 判断通过操作能否让字符串相等 II 力扣 2839. 判断通过操作能否让字符串相等 I 找规律 字符串 C++ 题解
c++·算法·leetcode·力扣·数组·找规律
xu_wenming2 小时前
在 TinyML 场景下,如何将模型从 FP32 量化为 INT8?
arm开发·算法·iot
csdn_aspnet2 小时前
C++ 求n边凸多边形的对角线数量(Find number of diagonals in n sided convex polygon)
开发语言·c++·算法
wsoz2 小时前
快速从C过渡到C++
c语言·开发语言·c++
深邃-3 小时前
字符函数和字符串函数(1)
c语言·开发语言·数据结构·c++·算法·html5
我真不是小鱼3 小时前
cpp刷题打卡记录24——路径总和 & 路径总和II
数据结构·c++·算法·leetcode
菜鸟小九3 小时前
JVM垃圾回收
java·jvm·算法
nianniannnn3 小时前
力扣 347. 前 K 个高频元素
c++·算法·leetcode