PAT 字符串处理专项之一

本文提供了PAT1001A+B、PAT1005SpellItRight、PAT1006SignInandSignOut及PAT1035Password等题目的详细解答。探讨了大数运算、时间格式比较和密码修改策略等问题,通过实例代码展示了如何处理超大数据、找到最早最晚时间点以及检查密码修改的有效性。

PAT 1001 A+B Format 思路见该博客。
PAT 1005 Spell It Right
PAT 1006 Sign In and Sign Out
PAT 1035 Password

PAT 1005 题解
  • 数据的数量级达到 10 0 100 100^{100} 100100,正常的整数类型不能够处理,因此要用字符串对整数进行处理。
#include<iostream>

using namespace std;

string english[10] = {"zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine"};

int main(){

    string num;
    cin >> num;

    int len = num.size();
    int res = 0;

    for (int i = 0; i < len; i++){
        res += num[i] - '0';
    }

    string r = to_string(res);

    int len2 = r.size();
    for (int j = 0; j < len2 - 1; j++){
        cout << english[r[j] - '0'] << " ";
    }

    cout << english[r[len2-1] - '0'];

    return 0;
}

 

PAT 1006 题解
  • 切入点:寻找最早到达时间 unlock,最晚离开时间 lock
  • 时间具有这样的格式 HH:MM:SS,便于时间的比较。

时间比较可以采用字典序的比较,可以使用字典序比较的关键在于位数相同

#include<iostream>

using namespace std;

int main(){

    int n;
    cin >> n;

    // o: ID, 1: Time
    string unlock[2];
    string lock[2];
    
    for (int i = 0; i < n; i++){
        string a, b, c;
        cin >> a >> b >> c;

        if (!i || b < unlock[1]){
            unlock[0] = a;
            unlock[1] = b;
        }

        if (!i || c > lock[1]){
            lock[0] = a;
            lock[1] = c;
        }
    }

    cout << unlock[0] << " " << lock[0];

    return 0;
}

/* 一开始自己做题时候的思路,用这个函数去实现时间的比较。
bool compare(string a, string b){

    int i = (a[0] - '0') * 10 + (a[1] - '0');
    int j = (b[0] - '0') * 10 + (b[1] - '0');

    if (i > j) return false;
    else if(i < j) return true;
    else{
        int i = (a[3] - '0') * 10 + (a[4] - '0');
        int j = (b[3] - '0') * 10 + (b[4] - '0');
        if (i > j) return false;
        else if(i < j) return true;
        else{
            int i = (a[6] - '0') * 10 + (a[7] - '0');
            int j = (b[6] - '0') * 10 + (b[7] - '0');
            if (i > j) return false;
            else if(i <= j) return true;
        }
    }

}*/

 

PAT 1035 题解
  • no modified account.
  • 输出注意单复数
#include <iostream>

using namespace std;
#define MAXN 1010

string res[MAXN];

int main(){

    int n;
    cin >> n;
    int n_copy = n;

    int count = 0;
    while(n--){

        string id, passwd;
        cin >> id >> passwd;
        bool flag = false;

        for(int i = 0; i < int(passwd.size()); i++){
            /*
				change函数,转换后的字符与当前字符相比较。
			*/
            switch (passwd[i]){
                case '0': {passwd[i] = '%'; flag=true; break;}
                case '1': {passwd[i] = '@'; flag=true; break;}
                case 'O': {passwd[i] = 'o'; flag=true; break;}
                case 'l': {passwd[i] = 'L'; flag=true; break;}
            }
        }

        if (flag)
            res[count++] = id + " " + passwd;
    }

    if (count){
        cout << count << endl;
        for (int i = 0; i < count; i++)
            cout << res[i] << endl;
    }else{
        if (n_copy > 1)
            cout << "There are " << n_copy << " accounts and no account is modified" << endl;
        else
            cout << "There is 1 account and no account is modified" << endl;
    }

    return 0;
}
C语言-光伏MPPT算法:电导增量法扰动观察法+自动全局搜索Plecs最大功率跟踪算法仿真内容概要:本文档主要介绍了一种基于C语言实现的光伏最大功率点跟踪(MPPT)算法,结合电导增量法与扰动观察法,并引入自动全局搜索策略,利用Plecs仿真工具对算法进行建模与仿真验证。文档重点阐述了两种经典MPPT算法的原理、优缺点及其在不同光照和温度条件下的动态响应特性,同时提出一种改进的复合控制策略以提升系统在复杂环境下的跟踪精度与稳定性。通过仿真结果对比分析,验证了所提方法在快速性和准确性方面的优势,适用于光伏发电系统的高效能量转换控制。; 适合人群:具备一定C语言编程基础和电力电子知识背景,从事光伏系统开发、嵌入式控制或新能源技术研发的工程师及高校研究人员;工作年限1-3年的初级至中级研发人员尤为适合。; 使用场景及目标:①掌握电导增量法与扰动观察法在实际光伏系统中的实现机制与切换逻辑;②学习如何在Plecs中搭建MPPT控制系统仿真模型;③实现自动全局搜索以避免传统算法陷入局部峰值问题,提升复杂工况下的最大功率追踪效率;④为光伏逆变器或太阳能充电控制器的算法开发提供技术参考与实现范例。; 阅读建议:建议读者结合文中提供的C语言算法逻辑与Plecs仿真模型同步学习,重点关注算法判断条件、步长调节策略及仿真参数设置。在理解基本原理的基础上,可通过修改光照强度、温度变化曲线等外部扰动因素,进一步测试算法鲁棒性,并尝试将其移植到实际嵌入式平台进行实验验证。
【无人机协同】动态环境下多无人机系统的协同路径规划与防撞研究(Matlab代码实现)​ 内容概要:本文围绕动态环境下多无人机系统的协同路径规划与防撞问题展开研究,提出基于Matlab的仿真代码实现方案。研究重点在于在复杂、动态环境中实现多无人机之间的高效协同飞行与避障,涵盖路径规划算法的设计与优化,确保无人机集群在执行任务过程中能够实时规避静态障碍物与动态冲突,保障飞行安全性与任务效率。文中结合智能优化算法,构建合理的成本目标函数(如路径长度、飞行高度、威胁规避、转弯角度等),并通过Matlab平台进行算法验证与仿真分析,展示多机协同的可行性与有效性。; 适合人群:具备一定Matlab编程基础,从事无人机控制、路径规划、智能优化算法研究的科研人员及研究生。; 使用场景及目标:①应用于灾害救援、军事侦察、区域巡检等多无人机协同任务场景;②目标是掌握多无人机系统在动态环境下的路径规划与防撞机制,提升协同作业能力与自主决策水平;③通过Matlab仿真深入理解协同算法的实现逻辑与参数调优方法。; 阅读建议:建议结合文中提供的Matlab代码进行实践操作,重点关注目标函数设计、避障策略实现与多机协同逻辑,配合仿真结果分析算法性能,进一步可尝试引入新型智能算法进行优化改进。
先展示下效果 https://pan.quark.cn/s/a4b39357ea24 StudentInfo 基于SSM的学生信息管理系统(选课) 已停更 项目简介: 由SpringMVC+MyBatis为主要框架,mysql8.0配置主从复制实现读写分离,主机丛机分别为腾讯云的服务器,而项目部署在阿里云上。 前端主要由bootstrap完成,背景用particles.js插件。 数据库交互查询用到pagehelper分页。 在添加修改相关功能时通过ajax来验证其主键是否存在可用。 代码层次清晰,输入框约束较高,已配置登录拦截。 一、应用技术 #### 工具:eclipse、navicat 环境:JDK1.8、tomcat9.0、mysql8.0 前端:JavaScript、jQuery、bootstrap4、particles.js 后端:maven、SpringMVC、MyBatis、ajax、mysql读写分离、mybatis分页 二、功能 #### 这是在上个springmvc选课系统的基础上进行修改完善的,目前功能基本相同,修复诸多bug,上个系统中有详细介绍:B/S基于springMVC的网上选课系统 主要功能模块图: 新增: 增加分页查询 输入框约束 学号、身份证、课程编号、教师编号只能输入数字,并且有最大输入限制,其中学号固定12位,若小于12位将会有提示。 姓名只能输入中文。 几乎所有输入框不能输入空格等约束 下拉框联动 添加、修改课程采用二级联动,即所属系别——所属专业; 添加、修改学生采用三级联动,即系别——专业——班级。 (三级联动代码有些复杂,因为JavaScript学的不好=-=)。 ajax+springmvc验证 用于验证学号、课程编号、教师...
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值