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;
}

源码地址: https://pan.quark.cn/s/a4b39357ea24 遗传算法 - 简书 遗传算法的理论是根据达尔文进化论而设计出来的算法: 人类是朝着好的方向(最优解)进化,进化过程中,会自动选择优良基因,淘汰劣等基因。 遗传算法(英语:genetic algorithm (GA) )是计算数学中用于解决最佳化的搜索算法,是进化算法的一种。 进化算法最初是借鉴了进化生物学中的一些现象而发展起来的,这些现象包括遗传、突变、自然选择、杂交等。 搜索算法的共同特征为: 首先组成一组候选解 依据某些适应性条件测算这些候选解的适应度 根据适应度保留某些候选解,放弃其他候选解 对保留的候选解进行某些操作,生成新的候选解 遗传算法流程 遗传算法的一般步骤 my_fitness函数 评估每条染色体所对应个体的适应度 升序排列适应度评估值,选出 前 parent_number 个 个体作为 待选 parent 种群(适应度函数的值越小越好) 从 待选 parent 种群 中随机选择 2 个个体作为父方和母方。 抽取父母双方的染色体,进行交叉,产生 2 个子代。 (交叉概率) 对子代(parent + 生成的 child)的染色体进行变异。 (变异概率) 重复3,4,5步骤,直到新种群(parentnumber + childnumber)的产生。 循环以上步骤直至找到满意的解。 名词解释 交叉概率:两个个体进行交配的概率。 例如,交配概率为0.8,则80%的“夫妻”会生育后代。 变异概率:所有的基因中发生变异的占总体的比例。 GA函数 适应度函数 适应度函数由解决的问决定。 举一个平方和的例子。 简单的平方和问 求函数的最小值,其中每个变量的取值区间都是 [-1, ...
《基于STM32微控制器集成温湿度监测与显示功能的系统实现方案》 本方案提供了一套完整的嵌入式系统设计参考,实现了环境参数的实时采集、可视化呈现与异常状态提示。系统核心采用意法半导体公司生产的STM32系列32位微控制器作为主控单元,负责协调各外设模块的工作流程。 系统通过数字式温湿度复合传感器周期性获取环境参数,该传感器采用单总线通信协议,具有响应迅速、数据可靠的特点。采集到的数值信息通过两种途径进行处理:首先,数据被传输至有机发光二极管显示屏进行实时图形化显示,该显示屏支持高对比度输出,能够在不同光照条件下清晰呈现当前温度与湿度数值;其次,所有采集数据同时通过通用异步收发传输接口输出,可供上位机软件进行记录与分析。 当监测参数超出预设安全范围时,系统会启动声学警示装置,该装置可发出不同频率的提示音,以区分温度异常或湿度异常状态。所有功能模块的驱动代码均采用模块化设计原则编写,包含完整的硬件抽象层接口定义、传感器数据解析算法、显示缓冲区管理机制以及串口通信协议实现。 本参考实现重点阐述了多外设协同工作的时序控制策略、低功耗数据采集模式的应用方法,以及确保系统稳定性的错误处理机制。代码库中包含了详细的初始化配置流程、中断服务程序设计和各功能模块的应用程序接口说明,为嵌入式环境监测系统的开发提供了可靠的技术实现范例。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值