每天一道C语言编程:合格密码的判定

简介: 每天一道C语言编程:合格密码的判定

题目描述

网上流传一句话:"常在网上飘啊,哪能不挨刀啊~"。其实要想能安安心心地上网其实也不难,学点安全知识就可以。

首先,我们就要设置一个安全的密码。那什么样的密码才叫安全的呢?一般来说一个比较安全的密码至少应该满足下面两个条件:

(1).密码长度大于等于8,且不要超过16。

(2).密码中的字符应该来自下面“字符类别”中四组中的至少三组。

这四个字符类别分别为:

1.大写字母:A,B,C...Z;

2.小写字母:a,b,c...z;

3.数字:0,1,2...9;

4.特殊符号:~,!,@,#,$,%,^;

给你一个密码,你的任务就是判断它是不是一个安全的密码。


输入格式

输入数据第一行包含一个数M,接下有M行,每行一个密码(长度最大可能为50),密码仅包括上面的四类字符。


输出格式

对于每个测试实例,判断这个密码是不是一个安全的密码,是的话输出YES,否则输出NO。


样例输入

3

a1b2c3d4

Linle@ACM

^~^@^@!%

样例输出

NO

YES

NO

思路


用num[4],分别保存四个字符类别,即


for(int i=0;i<len;i++)
            {
                if(str[i]>='0' && str[i]<='9')
                    num[0]++;
                if(str[i]>='a' && str[i]<='z')
                    num[1]++;
                if(str[i]>='A' && str[i]<='Z')
                    num[2]++;
                else
                    num[3]++;
            }

再用sum记录num=0的次数,如果num>=2,表示没有使用三种以上的字符类别,即


for(int i=0;i<4;i++)
            {
                if(num[i]==0)
                    sum++;
            }
            if(sum>=2)
                printf("NO\n");
            else
                printf("YES\n");

所以,最终代码为


#include<stdio.h>
#include<string.h>
int main()
{
    int m;
    scanf("%d",&m);
    while(m--)
    {
        int num[4]={0};
        char str[30];
        scanf("%s",str);
        int len=strlen(str);
        if(len>=8 && len<=16)
        {
            for(int i=0;i<len;i++)
            {
                if(str[i]>='0' && str[i]<='9')
                    num[0]++;
                if(str[i]>='a' && str[i]<='z')
                    num[1]++;
                if(str[i]>='A' && str[i]<='Z')
                    num[2]++;
                if(str[i] == '~' ||  str[i]== '!' || str[i] == '@' || str[i] == '#' || str[i] == '$' || str[i] == '%' || str[i] == '^')
                    num[3]++;
            }
            int sum=0;
            for(int i=0;i<4;i++)
            {
                if(num[i]==0)
                    sum++;
            }
            if(sum>=2)
                printf("NO\n");
            else
                printf("YES\n");
        }
    }
    return 0;
}


与之相似的:统计字母


题目描述

给定一段文章,请输出每个字母出现的次数


输入格式

只有一组输入数据,该数据大小<10KB。在文章中除最后一个字符外,只有小写字母、空格和换行符,没有另外的标点、数字和大写字母等。该文章以’#’结尾。


输出格式

输出格式为“C A”,C为’a’..’z’中的字母,A为出现次数,C和A之间空一格


样例输入

here is the input

this is the article#

样例输出

a 1

b 0

c 1

d 0

e 5

f 0

g 0

h 4

i 5

j 0

k 0

l 1

m 0

n 1

o 0

p 1

q 0

r 2

s 3

t 5

u 1

v 0

w 0

x 0

y 0

z 0

代码如下


#include<stdio.h>
#include<string.h>
int main(){
    char a;
    int b[26]={0},i;
    while(1)
    {
        a=getchar();
        if(a=='#')
            break;
        b[(int)(a-97)]++;
    }
    char str[]="abcdefghijklmnopqrstuvwxyz";
    for(i=0;i<26;i++)
    {
        printf("%c %d\n",str[i],b[i]);
    }
    return 0;
}


也可以用*p="abcdefghijklmnopqrstuvwxyz"


这样就可以直接


for(i=0;i<26;i++)

        printf("%c %d\n",*p++,b[i]);



#include<stdio.h>
#include<string.h>
int main(){
    char a,*p="abcdefghijklmnopqrstuvwxyz";
    int b[26]={0},i;
    while(1)
    {
        a=getchar();
        if(a=='#')
            break;
        b[(int)(a-97)]++;
    }
    for(i=0;i<26;i++)
    {
        printf("%c %d\n",*p++,b[i]);
    }
    return 0;
}
根据输出的格式也可以用二元数组
#include<stdio.h>
int main()
{
    char k;
    int a[26][2],i=0,j=0,t;
    for(i=0;i<26;i++)
    for(j=0;j<2;j++)
    {
        a[i][0]=i+97;//a[i][0]存入的是26个字母
        a[i][1]=0;//a[i][1]是26个字母对应出现的次数
    }
    while(scanf("%c",&k) && k!='#')//当输入的字符不是#时循环
    {
        t=k;
        if(t>=97 && t<123)//这种字符是26个字母时
            a[t-97][1]++;//对应的字母个数加一
    }
    for(i=0;i<26;i++)
        printf("%c %d\n",a[i][0],a[i][1]);//最后输出对应字母及其个数
    return 0;
}
目录
相关文章
|
18天前
|
存储 编译器 C语言
【C语言】数据类型全解析:编程效率提升的秘诀
在C语言中,合理选择和使用数据类型是编程的关键。通过深入理解基本数据类型和派生数据类型,掌握类型限定符和扩展技巧,可以编写出高效、稳定、可维护的代码。无论是在普通应用还是嵌入式系统中,数据类型的合理使用都能显著提升程序的性能和可靠性。
40 8
|
21天前
|
C语言
C语言编程中,错误处理至关重要,能提升程序的健壮性和可靠性
C语言编程中,错误处理至关重要,能提升程序的健壮性和可靠性。本文探讨了C语言中的错误类型(如语法错误、运行时错误)、基本处理方法(如返回值、全局变量、自定义异常处理)、常见策略(如检查返回值、设置标志位、记录错误信息)及错误处理函数(如perror、strerror)。强调了不忽略错误、保持处理一致性及避免过度处理的重要性,并通过文件操作和网络编程实例展示了错误处理的应用。
55 4
|
2月前
|
NoSQL C语言 索引
十二个C语言新手编程时常犯的错误及解决方式
C语言初学者常遇错误包括语法错误、未初始化变量、数组越界、指针错误、函数声明与定义不匹配、忘记包含头文件、格式化字符串错误、忘记返回值、内存泄漏、逻辑错误、字符串未正确终止及递归无退出条件。解决方法涉及仔细检查代码、初始化变量、确保索引有效、正确使用指针与格式化字符串、包含必要头文件、使用调试工具跟踪逻辑、避免内存泄漏及确保递归有基准情况。利用调试器、编写注释及查阅资料也有助于提高编程效率。避免这些错误可使代码更稳定、高效。
422 12
|
3月前
|
存储 算法 Linux
C语言 多进程编程(一)进程创建
本文详细介绍了Linux系统中的进程管理。首先,文章解释了进程的概念及其特点,强调了进程作为操作系统中独立可调度实体的重要性。文章还深入讲解了Linux下的进程管理,包括如何获取进程ID、进程地址空间、虚拟地址与物理地址的区别,以及进程状态管理和优先级设置等内容。此外,还介绍了常用进程管理命令如`ps`、`top`、`pstree`和`kill`的使用方法。最后,文章讨论了进程的创建、退出和等待机制,并展示了如何通过`fork()`、`exec`家族函数以及`wait()`和`waitpid()`函数来管理和控制进程。此外,还介绍了守护进程的创建方法。
C语言 多进程编程(一)进程创建
|
3月前
|
Linux C语言
C语言 多进程编程(三)信号处理方式和自定义处理函数
本文详细介绍了Linux系统中进程间通信的关键机制——信号。首先解释了信号作为一种异步通知机制的特点及其主要来源,接着列举了常见的信号类型及其定义。文章进一步探讨了信号的处理流程和Linux中处理信号的方式,包括忽略信号、捕捉信号以及执行默认操作。此外,通过具体示例演示了如何创建子进程并通过信号进行控制。最后,讲解了如何通过`signal`函数自定义信号处理函数,并提供了完整的示例代码,展示了父子进程之间通过信号进行通信的过程。
|
3月前
|
Linux C语言
C语言 多进程编程(四)定时器信号和子进程退出信号
本文详细介绍了Linux系统中的定时器信号及其相关函数。首先,文章解释了`SIGALRM`信号的作用及应用场景,包括计时器、超时重试和定时任务等。接着介绍了`alarm()`函数,展示了如何设置定时器以及其局限性。随后探讨了`setitimer()`函数,比较了它与`alarm()`的不同之处,包括定时器类型、精度和支持的定时器数量等方面。最后,文章讲解了子进程退出时如何利用`SIGCHLD`信号,提供了示例代码展示如何处理子进程退出信号,避免僵尸进程问题。
|
3月前
|
消息中间件 Unix Linux
C语言 多进程编程(五)消息队列
本文介绍了Linux系统中多进程通信之消息队列的使用方法。首先通过`ftok()`函数生成消息队列的唯一ID,然后使用`msgget()`创建消息队列,并通过`msgctl()`进行操作,如删除队列。接着,通过`msgsnd()`函数发送消息到消息队列,使用`msgrcv()`函数从队列中接收消息。文章提供了详细的函数原型、参数说明及示例代码,帮助读者理解和应用消息队列进行进程间通信。
|
3月前
|
缓存 Linux C语言
C语言 多进程编程(六)共享内存
本文介绍了Linux系统下的多进程通信机制——共享内存的使用方法。首先详细讲解了如何通过`shmget()`函数创建共享内存,并提供了示例代码。接着介绍了如何利用`shmctl()`函数删除共享内存。随后,文章解释了共享内存映射的概念及其实现方法,包括使用`shmat()`函数进行映射以及使用`shmdt()`函数解除映射,并给出了相应的示例代码。最后,展示了如何在共享内存中读写数据的具体操作流程。
|
3月前
|
消息中间件 Unix Linux
C语言 多进程编程(二)管道
本文详细介绍了Linux下的进程间通信(IPC),重点讨论了管道通信机制。首先,文章概述了进程间通信的基本概念及重要性,并列举了几种常见的IPC方式。接着深入探讨了管道通信,包括无名管道(匿名管道)和有名管道(命名管道)。无名管道主要用于父子进程间的单向通信,有名管道则可用于任意进程间的通信。文中提供了丰富的示例代码,展示了如何使用`pipe()`和`mkfifo()`函数创建管道,并通过实例演示了如何利用管道进行进程间的消息传递。此外,还分析了管道的特点、优缺点以及如何通过`errno`判断管道是否存在,帮助读者更好地理解和应用管道通信技术。
|
3月前
|
Linux C语言
C语言 多进程编程(七)信号量
本文档详细介绍了进程间通信中的信号量机制。首先解释了资源竞争、临界资源和临界区的概念,并重点阐述了信号量如何解决这些问题。信号量作为一种协调共享资源访问的机制,包括互斥和同步两方面。文档还详细描述了无名信号量的初始化、等待、释放及销毁等操作,并提供了相应的 C 语言示例代码。此外,还介绍了如何创建信号量集合、初始化信号量以及信号量的操作方法。最后,通过实际示例展示了信号量在进程互斥和同步中的应用,包括如何使用信号量避免资源竞争,并实现了父子进程间的同步输出。附带的 `sem.h` 和 `sem.c` 文件提供了信号量操作的具体实现。