2020PTA天梯赛团队赛

这篇博客介绍了两个编程题目,包括检查密码的合法性,需要密码包含字母和数字且长度至少6位;另一个是找到给定数字串中最早的指定长度素数。还涉及到身份证号码校验码的计算规则和有效性验证。
摘要由CSDN通过智能技术生成

检查密码

L1-6 检查密码 (15分)
本题要求你帮助某网站的用户注册模块写一个密码合法性检查的小功能。该网站要求用户设置的密码必须由不少于6个字符组成,并且只能有英文字母、数字和小数点 .,还必须既有字母也有数字。
输入格式:

输入第一行给出一个正整数 N(≤ 100),随后 N 行,每行给出一个用户设置的密码,为不超过 80 个字符的非空字符串,以回车结束。
输出格式:

对每个用户的密码,在一行中输出系统反馈信息,分以下5种:
如果密码合法,输出Your password is wan mei.;
如果密码太短,不论合法与否,都输出Your password is tai duan le.;
如果密码长度合法,但存在不合法字符,则输出Your password is tai luan le.;
如果密码长度合法,但只有字母没有数字,则输出Your password needs shu zi.;
如果密码长度合法,但只有数字没有字母,则输出Your password needs zi mu.。
输入样例:

5
123s
zheshi.wodepw
1234.5678
WanMei23333
pass*word.6
输出样例:

Your password is tai duan le.
Your password needs shu zi.
Your password needs zi mu.
Your password is wan mei.
Your password is tai luan le.

代码实现


#include <stdio.h>
#include<ctype.h>

int main()
{
   
        char c;
        int n, count, digit, alpha, notdot;

        scanf("%d\n", &n);
        while (n--) {
   
                count = 0; alpha = 0;
                digit = 0; notdot = 0;
                while ((c = getchar()) != '\n') {
   
                        count++;
                        if (isdigit(c))
                                digit++;
                        else if (isalpha(c))
                                alpha++;
                        else if (c != '.')
                                notdot++;
                }
                if (count < 6)
                        puts("Your password is tai duan le.");
                else if (notdot)
                        puts("Your password is tai luan le.");
                else if (alpha && !digit)
                        puts("Your password needs shu zi.");
                else if (digit && !alpha)
                        puts("Your password needs zi mu.");
                else
                        puts("Your password is wan mei.");
        }

        return 0;
}   

总结知识点
1、添加 #include<ctype.h>
可利用 函数isdigit() isalpha()分别计算数字和字母的个数
代替 ASCII字码比较;
2、利用while(n–)代替 for(int =0;i<n;i++);

L1-7 谷歌的招聘 (20分)

2004 年 7 月,谷歌在硅谷的 101 号公路边竖立了一块巨大的广告牌(如下图)用于招聘。内容超级简单,就是一个以 .com 结尾的网址,而前面的网址是一个 10 位素数,这个素数是自然常数 e 中最早出现的 10 位连续数字。能找出这个素数的人,就可以通过访问谷歌的这个网站进入招聘流程的下一步。
自然常数 e 是一个著名的超越数,前面若干位写出来是这样的:e = 2.718281828459045235360287471352662497757247093699959574966967627724076630353547594571382178525166427427466391932003059921… 其中粗体标出的 10 位数就是答案。
本题要求你编程解决一个更通用的问题:从任一给定的长度为 L 的数字中,找出最早出现的 K 位连续数字所组成的素数。
输入格式:

输入在第一行给出 2 个正整数,分别是 L(不超过 1000 的正整数,为数字长度)和 K(小于 10 的正整数)。接下来一行给出一个长度为 L 的正整数 N。
输出格式:

在一行中输出 N 中最早出现的 K 位连续数字所组成的素数。如果这样的素数不存在,则输出 404。注意,原始数字中的前导零也计算在位数之内。例如在 200236 中找 4 位素数,0023 算是解;但第一位 2 不能被当成 0002 输出,因为在原始数字中不存在这个 2 的前导零。
输入样例 1:

20 5
23654987725541023819
输出样例 1:

49877
输入样例 2:

10 3
2468024680
输出样例 2:

404

#include <iostream>
#include <string
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值