PAT-Basic刷题1041-1050

本文集包含多个C++编程挑战题目,涉及考试座位号管理、字符统计、特定字符串输出、火星数字转换、快速排序、划拳游戏策略、团队比赛计分、数字加密算法、数列片段和计算、以及螺旋矩阵构建等。每个题目都提供了完整的代码实现,帮助读者深入理解C++编程技巧。

1041 考试座位号

#include<iostream>
#include<string>
using namespace std;
int main(){
    string stu[1005][2];
    string s1,s2;
    int m,n,t;
    cin>>n;
    for(int i=0;i<n;i++){
        cin>>s1>>t>>s2;
        stu[t][0]=s1;
        stu[t][1]=s2;
    }
    cin>>m;
    for(int i=0;i<m;i++){
        cin>>t;
        cout<<stu[t][0]<<" "<<stu[t][1]<<endl;
    }
    return 0;
}

1042 字符统计

#include<iostream>
#include<cstdio>
#include<string>
using namespace std;
int main(void){
    string s;
    getline(cin,s);
    int a[26]={0};
    for(int i=0;i<s.size();i++){
        s[i]=tolower(s[i]);
        if(islower(s[i])) 
            a[s[i]-'a']++;
    }
    int m=a[0],n=0;
    for(int i=0;i<26;i++){
        if(a[i]>m){
            m=a[i];
            n=i;
        }
    }
    printf("%c %d",'a'+n,m);  
    
    return 0;
}

1043 输出PATest

#include<iostream>
using namespace std;
int main(void){
    int map[128]={0};
    int c;
    while((c=cin.get())!=EOF) map[c]++;
    while(map['P']>0||map['A']>0||map['T']>0||map['e']>0||map['s']>0||map['t']>0){
        if(map['P']-->0) cout<<"P";
        if(map['A']-->0) cout<<"A";
        if(map['T']-->0) cout<<"T";
        if(map['e']-->0) cout<<"e";
        if(map['s']-->0) cout<<"s";
        if(map['t']-->0) cout<<"t";
    }
    return 0;
}

1044 火星数字

#include<iostream>
#include<string>
using namespace std;
string a[13]={"tret","jan", "feb", "mar", "apr", "may", "jun", "jly", "aug", "sep", "oct", "nov", "dec"};
string b[13]={"####","tam", "hel", "maa", "huh", "tou", "kes", "hei", "elo", "syy", "lok", "mer", "jou"};
string s;
void fun1(int t){
    if(t/13) cout<<b[t/13];
    if((t/13)&&(t%13)) cout<<" ";
    if((t%13||t==0)) cout<<a[t%13];
}
void fun2(){
    int t1=0,t2=0;
    string s1=s.substr(0,3),s2;
    if(s.size()>4) s2=s.substr(4,3);
    for(int i=1;i<=12;i++){
        if(s1==a[i]||s2==a[i]) t2=i;
        if(s1==b[i]) t1=i;
    }
    cout<<t1*13+t2;
}
int main(){
    int n;cin>>n;
    getchar();
    for(int i=0;i<n;i++){
        getline(cin,s);
        if(s[0]>='0'&&s[0]<='9')
            fun1(stoi(s));
        else
            fun2();
        cout<<endl;
    }
    return 0;
}

1045 快速排序

#include<iostream>
#include<algorithm>
#include<vector>
#include<cstdio>
using namespace std;
int main(void){
    int n,cnt=0;
    cin>>n;
    vector<int> a(n),b(n),v(n);
    for(int i=0;i<n;i++){
        cin>>a[i];
        b[i]=a[i];
    }
    int m=0;
    sort(a.begin(),a.end());
    for(int i=0;i<n;i++){
        if(a[i]==b[i]&&b[i]>m){
            v[cnt++]=b[i];
        }
        if(b[i]>m)
            m=b[i];
    }
    printf("%d\n",cnt);
    for(int i=0;i<cnt;i++){
        if(i!=0) printf(" ");
        cout<<v[i];
    }
    printf("\n");
    return 0;
}

1046 划拳

#include<iostream>
using namespace std;
int main(void){
    int n;
    cin>>n;
    int a[4];
    int m1=0,m2=0;
    while(n--){
        cin>>a[0]>>a[1]>>a[2]>>a[3];
        int n=a[0]+a[2];
        if(n==a[1]&&n!=a[3]) m2++;
        if(n==a[3]&&n!=a[1]) m1++;
    }
    printf("%d %d",m1,m2);
    return 0;
}

1047 编程团体赛

#include<iostream>
using namespace std;
int main(void){
    int n;
    cin>>n;
    int team[1001]={0},score,num,t,m;
    for(int i=0;i<n;i++){
        scanf("%d-%d %d",&t,&num,&score);
        team[t]+=score;
    }
    for(int i=0;i<1001;i++){
        if(team[i]>team[m]){
            m=i;
        }
    }
    printf("%d %d",m,team[m]);
    return 0;
}

1048 数字加密

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int main(void){
    string a,b,c;
    cin>>a>>b;
    reverse(a.begin(),a.end());reverse(b.begin(),b.end());
    if(a.size()>b.size())
        b.append(a.size()-b.size(),'0');
    if(a.size()<b.size())
        a.append(b.size()-a.size(),'0');
    char str[14] = {"0123456789JQK"};
    for(int i=0;i<a.size();i++){
        if(i%2==0){
            c+=str[(a[i]-'0'+b[i]-'0')%13];
        }
        else{
            int m=b[i]-a[i];
            if(m<0) m+=10;
            c+=str[m];
        }
    }
    for(int i=c.size()-1;i>=0;i--)
        cout<<c[i];
    return 0;
}

1049 数列的片段和

#include<iostream>
#include<cstdio>
using namespace std;
int main(void){
    int n;
    cin>>n;
    double sum=0.0,temp;
    for(int i=1;i<=n;i++){
        cin>>temp;
        sum+=temp*i*(n-i+1);
    }
    printf("%.2f",sum);
    return 0;
}

1050 螺旋矩阵

#include<iostream>
#include<vector>
#include<algorithm>
#include<cmath>
#include<cstdio>
using namespace std;
bool cmp(int a,int b){return a>b;}
int main(void){
    int N;
    cin>>N;
    int m,n,t=0; \
     for (n = sqrt((double)N); n >= 1; n--) {
        if (N % n == 0) {
            m = N / n;
            break;
        }
    }
    vector<int> a(N);
    for(int i=0;i<N;i++)
        scanf("%d",&a[i]);
    sort(a.begin(),a.end(),cmp);
    vector<vector<int> > b(m,vector<int>(n));
    for(int i=0;i<m/2+m%2;i++){
        for (int j = i; j <= n - 1 - i && t <= N - 1; j++)
                b[i][j] = a[t++];
        for (int j = i + 1; j <= m - 2 - i && t <= N - 1; j++)
                b[j][n - 1 - i] = a[t++];
        for (int j = n - i - 1; j >= i && t <= N - 1; j--)
                b[m - 1 - i][j] = a[t++];
        for (int j = m - 2 - i; j >= i + 1 && t <= N - 1; j--)
                b[j][i] = a[t++];
    }
    for (int i = 0; i < m; i++) {
        for (int j = 0 ; j < n; j++) {
            printf("%d", b[i][j]);
            if (j != n - 1) printf(" ");
        }
        printf("\n");
    }
    return 0;
}

内容概要:本文详细介绍了一个基于C++的养老院管理系统的设计与实现,旨在应对人口老龄化带来的管理挑战。系统通过整合住户档案、健康监测、护理计划、任务调度等核心功能,构建了从数据采集、清洗、AI风险预测到服务调度与可视化的完整技术架构。采用C++高性能服务端结合消息队列、规则引擎和机器学习模型,实现了健康状态实时监控、智能任务分配、异常告警推送等功能,并解决了多源数据整合、权限安全、老旧硬件兼容等实际问。系统支持模块化扩展与流程自定义,提升了养老服务效率、医护协同水平和住户安全保障,同时为运营决策提供数据支持。文中还提供了关键模块的代码示例,如健康指数算法、任务调度器和日志记录组件。; 适合人群:具备C++编程基础,从事软件开发或系统设计工作1-3年的研发人员,尤其是关注智慧养老、医疗信息系统开发的技术人员。; 使用场景及目标:①学习如何在真实项目中应用C++构建高性能、可扩展的管理系统;②掌握多源数据整合、实时健康监控、任务调度与权限控制等复杂业务的技术实现方案;③了解AI模型在养老场景中的落地方式及系统架构设计思路。; 阅读建议:此资源不仅包含系统架构与模型描述,还附有核心代码片段,建议结合整体设计逻辑深入理解各模块之间的协同机制,并可通过重构或扩展代码来加深对系统工程实践的掌握。
内容概要:本文详细介绍了一个基于C++的城市交通流量数据可视化分析系统的设计与实现。系统涵盖数据采集与预处理、存储与管理、分析建模、可视化展示、系统集成扩展以及数据安全与隐私保护六大核心模块。通过多源异构数据融合、高效存储检索、实时处理分析、高交互性可视化界面及模块化架构设计,实现了对城市交通流量的实时监控、历史趋势分析与智能决策支持。文中还提供了关键模块的C++代码示例,如数据采集、清洗、CSV读写、流量统计、异常检测及基于SFML的柱状图绘制,增强了系统的可实现性与实用性。; 适合人群:具备C++编程基础,熟悉数据结构与算法,有一定项目开发经验的高校学生、研究人员及从事智能交通系统开发的工程师;适合对大数据处理、可视化技术和智慧城市应用感兴趣的技术人员。; 使用场景及目标:①应用于城市交通管理部门,实现交通流量实时监测与拥堵预警;②为市民出行提供路径优化建议;③支持交通政策制定与信号灯配时优化;④作为智慧城市建设中的智能交通子系统,实现与其他城市系统的数据协同。; 阅读建议:建议结合文中代码示例搭建开发环境进行实践,重点关注多线程数据采集、异常检测算法与可视化实现细节;可进一步扩展机器学习模型用于流量预测,并集成真实交通数据源进行系统验证。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值