IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 第九届编程大赛预选赛 -> 正文阅读

[C++知识库]第九届编程大赛预选赛

第九届编程大赛预选赛

  • 有些题目可能有c++版本和py版本
一、YYDS
题目链接:

https://www.xujcoj.com/home/problem/detail/3617

c++_code:
#include<bits/stdc++.h>
using namespace std;
//也可以用sort()函数
int main(){
    int m;
    cin>>m;
    set<string>s;
    getchar();//清除m的换行符
    while(m--){
        string x;
        getline(cin,x);
        s.insert(x);//set自动排序
    }
    for(auto it:s){
        printf("%s YYDS!\n",it.c_str());
    }
}
python_code:
a=list()
m=eval(input())
while m:
    m-=1
    s=input()
    a.append(s)
a.sort()
for i in a:
    print('{} YYDS!'.format(i))
二、TCL和TQL
题目链接:

https://www.xujcoj.com/home/problem/detail/3618

c++_code:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int main() {
    int n;
    cin>>n;
    for(int i=1;i<=n;i++){
        int m;
        cin>>m;
        int a[m];
        int sum=0;
        for(int j=0;j<m;j++){
            cin>>a[j];
            sum+=a[j];
        }//一定要读完
        int cnt=0;
        for(int j=0;j<m;j++){
            if(a[j]<60){
                printf("No.%d TCL\n",i);
                break;
            }
            if(a[j]>=85)
                cnt++;
        }
        if(cnt==m&&sum>=90*m)//除法可能有精度问题
            printf("No.%d TQL\n",i);
    }
}
python_code:
n = eval(input())
for i in range(1, n + 1):
    score = list(map(int, input().split()))
    m = score[0]
    score.remove(m)
    _sum = sum(score)
    cnt = 0
    for j in score:
        if j < 60:
            print('No.{} TCL'.format(i))
            break
        if j >= 85:
            cnt += 1
    if cnt == m and _sum >= 90 * m:
        print('No.{} TQL'.format(i))

三、市质检的分数
题目链接:

https://www.xujcoj.com/home/contest/1098/problem/3

算法:

前缀和

c++_code:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn=1e6+5;
int d[maxn][11];//前缀和数组,第一个代表学生序号,第二个1-9代表各科成绩,10代表总成绩
int main() {
    int m;
    scanf("%d",&m);//此题cin和scanf差的时间很大,所以用scanf
    for (int i = 1; i <= m; ++i) {
        int sum=0;
        for(int j=1;j<=9;++j){
            int x;
            scanf("%d",&x);//直接读入数据不增开数组,增开会导致内存溢出
            sum+=x;
            d[i][j]=d[i-1][j]+x;
        }
        d[i][10]=d[i-1][10]+sum;
    }
    int q;//开始查询
    scanf("%d",&q);
    while(q--){
        int a,b;
        string c;
        scanf("%d %d",&a,&b);
        cin>>c;//我不会用scanf读字符串
        if(c=="ALL"){
            cout<<(d[b][10]-d[a-1][10])/(b-a+1)<<endl;
        }
        else{
            int x=c[1]-'0';
            cout<<(d[b][x]-d[a-1][x])/(b-a+1)<<endl;
        }
    }
}
四、回文姓名
题目链接:

https://www.xujcoj.com/home/problem/detail/3620

c++_code:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
//这题应该有很多想法,我的想法是找到韵母前的声母位置,要特判o和h,因为ou可以成为一个拼音,h前还能跟z、c、s,然后进行对比
int main() {
    int m;
    cin >> m;
    while (m--) {
        string xing, ming;
        cin >> xing >> ming;
        int pos = 0;
        bool f = 0;
        for (int i = 2; i < ming.size(); ++i) {
            if (ming[i] == 'a' || ming[i] == 'e' || ming[i] == 'i' || ming[i] == 'o' || ming[i] == 'u') {
                if (ming[i] == 'o') {
                    if (ming[i - 1] == 'a' || ming[i - 1] == 'e' || ming[i - 1] == 'i' || ming[i - 1] == 'o' ||ming[i - 1] == 'u') {
                        pos = i;
                        f++;
                    }
                    else if (ming[i - 1] != 'a' && ming[i - 1] != 'e' && ming[i - 1] != 'i' && ming[i - 1] != 'o' &&ming[i - 1] != 'u') {
                        if (ming[i - 1] == 'h') {
                            if (ming[i - 2] == 'z' || ming[i - 2] == 'c' || ming[i - 2] == 's') {
                                pos = i - 2;
                                f++;
                            }
                            else {
                                pos = i - 1;
                                f++;
                            }
                        }
                        else {
                            pos = i - 1;
                            f++;
                        }
                    }
                }
                else {
                    if (ming[i - 1] != 'a' && ming[i - 1] != 'e' && ming[i - 1] != 'i' && ming[i - 1] != 'o' &&ming[i - 1] != 'u') {
                        if (ming[i - 1] == 'h') {
                            if (ming[i - 2] == 'z' || ming[i - 2] == 'c' || ming[i - 2] == 's') {
                                pos = i - 2;
                                f++;
                            }
                            else {
                                pos = i - 1;
                                f++;
                            }
                        }
                        else{
                            pos=i-1;
                            f++;
                        }
                    }
                }
            }
        }
        string ans;
        ans = pos == 1 ? ming : ming.substr(pos);
        if (ans[0] >= 'a' && ans[0] <= 'z')
            ans[0] = char(ans[0] - 32);
        //cout << ans << endl;
        if(ans==xing)puts("Yes");
        else puts("No");
    }
}
五、孤独的岛屿
题目链接:

https://www.xujcoj.com/home/problem/detail/3622

算法:

并查集

c++_code:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int pre[114];
int find(int x){//找到根节点
    return x==pre[x]?x:find(pre[x]);
}
int main() {
    int n;
    cin >> n;
    while (n--) {
        int m, p;
        cin >> m >> p;
        for (int i = 1; i <= m; i++) {
            pre[i] = i;//所有岛屿都还没连接
        }
        while (p--) {
            int a, b;
            cin >> a >> b;
            int x = find(a);
            int y = find(b);
            if (x != y) pre[x] = pre[y];//如果没有间接连接,就连接
        }
        set<int> ans;
        for (int j = 1; j <= m; j++) {
            ans.insert(find(j));//set存不同的根节点
        }
        cout<<((ans.size()==1)?0:ans.size())<<endl;
    }
}
python_code:
pre=[0 for x in range(114) ]


def find(x):
    if x==pre[x]:
        return x
    else:
        return find(pre[x])

    
n=eval(input())
while n:
    n-=1
    k = [0 for x in range(114)]
    m,p=map(int,input().split())
    for i in range(1,m+1):
        pre[i]=i
    while p:
        p-=1
        a,b=map(int,input().split())
        x=find(a)
        y=find(b)
        if x!=y:
            pre[x]=pre[y]
    for i in range(1,m+1):
        k[find(i)]=1
    ans=0
    for i in range(1,m+1):
        if k[i]:
            ans+=1
    if ans==1:
        ans=0
    print(ans)


六、牧夫座空洞
题目链接:

https://www.xujcoj.com/home/problem/detail/3624

算法:

BFS、DFS

DFS_code:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
ll T,a,b,c;
int book[14][14][14];
ll dir[6][3]={1,0,0,-1,0,0,0,1,0,0,-1,0,0,0,1,0,0,-1};
ll dfs(int x,int y,int z)
{
    if(book[x][y][z])return 0;
    ll tx,ty,tz,ans=1;
    book[x][y][z]=1;
    for(ll i=0;i<6;i++)
    {
        tx=x+dir[i][0];
        ty=y+dir[i][1];
        tz=z+dir[i][2];
        ans+=dfs(tx,ty,tz);
    }
    return ans;
}
int main() {
    int n;
    cin>>n;
    while(n--){
        int a,b,c;
        cin>>a>>b>>c;
        memset(book,1,sizeof(book));//初始化
        for (int i = 1; i <= a; ++i) {//输入
            for (int j = 1; j <= b; ++j) {
                for (int k = 1; k <= c; ++k) {
                    cin>>book[i][j][k];
                }
            }
        }
        ll ans=1;
        for (int i = 1; i <= a; ++i) {//搜索
            for (int j = 1; j <= b; ++j) {
                for (int k = 1; k <= c; ++k) {
                        if(!book[i][j][k])
                            ans=max(ans,dfs(i,j,k));
                }
            }
        }
        cout<<ans<<endl;
    }
}
BFS_code:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int h[14][14][14];
int x,y,z;
int dir[6][3]{1,0,0,-1,0,0,0,1,0,0,-1,0,0,0,1,0,0,-1};
struct hole{
    int x,y,z;
};
int bfs(int a,int b,int c){//标准模板
    int ans=1;
    queue<hole>q;
    h[a][b][c]=1;
    q.push({a,b,c});
    while(q.size()){
        hole now=q.front();
        q.pop();
        hole next;
        for (int i = 0; i <6 ; ++i) {
            next.x=now.x+dir[i][0];
            next.y=now.y+dir[i][1];
            next.z=now.z+dir[i][2];
            if(next.x>=1&&next.x<=x&&next.y>=1&&next.y<=y&&next.z>=1&&next.z<=z) {
                if(!h[next.x][next.y][next.z]){
                    ans++;
                    q.push(next);
                    h[next.x][next.y][next.z]=1;
                }
            }
        }
    }
    return ans;
}
int main(){
    int n;
    cin>>n;
    while(n--){
       memset(h,1,sizeof(h));//初始化
        cin>>x>>y>>z;
        for (int i = 1; i <=x; ++i) {//输入
            for (int j = 1; j <=y ; ++j) {
                for (int k = 1; k <=z ; ++k) {
                    cin>>h[i][j][k];
                }
            }
        }
        int ans=0;
        for (int i = 1; i <=x; ++i) {//搜索
            for (int j = 1; j <=y ; ++j) {
                for (int k = 1; k <=z ; ++k) {
                    if(!h[i][j][k])
                        ans=max(ans,bfs(i,j,k));
                }
            }
        }
        cout<<ans<<endl;
    }
}
七、数列-9
题目链接:

https://www.xujcoj.com/home/problem/detail/3621

算法:

矩阵快速幂

c++_code:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int mod=100000007;
ll t[10][10];
void multi(ll a[10][10],ll b[10][10]){//矩阵的乘法
    fill((ll*)t,(ll*)t+10*10,0);
    for (int i=0; i<10; i++){
        for (int j = 0; j < 10; ++j) {
            for (int k = 0; k < 10;++k){
                t[i][j]=(t[i][j]+a[i][k]*b[k][j])%mod;
            }
        }
    }
    for (int i=0; i<10; ++i){
        for (int j = 0; j < 10; ++j){
            a[i][j]=t[i][j];
        }
    }
}
ll r[10][10];
void qp(ll a[10][10],int n){//矩阵快速幂(类似数乘的快速幂)
    fill((ll*)r,(ll*)r+10*10,0);
    for (int i = 0; i < 10; ++i) {
        r[i][i]=1;
    }
    while(n){
        if(n&1) multi(r,a);
        multi(a,a);
        n>>=1;
    }
}
int main() {
    int n;
    cin>>n;
    while(n--){
        //矩阵A(1,2,3,4,5,6,7,8,9,10)
        //AXB=(2,3,4,5,6,7,8,9,10,1*1+2*2+……+10*10)
        //所以AXB的最后一项就是得到的结果
        //线代好高深,我好菜!!!
        //观察得A*B^2就是第12项;
        //所以 第n项就是A*B^(n-10)的最后一项
        ll b[10][10]={
                {0,0,0,0,0,0,0,0,0,1},
                {1,0,0,0,0,0,0,0,0,2},
                {0,1,0,0,0,0,0,0,0,3},
                {0,0,1,0,0,0,0,0,0,4},
                {0,0,0,1,0,0,0,0,0,5},
                {0,0,0,0,1,0,0,0,0,6},
                {0,0,0,0,0,1,0,0,0,7},
                {0,0,0,0,0,0,1,0,0,8},
                {0,0,0,0,0,0,0,1,0,9},
                {0,0,0,0,0,0,0,0,1,10},
        };
        ll a[10],m;
        for (int i = 0; i < 10; ++i) {
            cin>>a[i];
        }
        cin>>m;
        if(m<=10)cout<<a[m-1]<<endl;//项数小于10直接输出,不用乘
        else{
            qp(b,m-10);
            ll ans=0;
            for (int i = 0; i < 10; ++i) {
                ans=(ans+a[i]*r[i][9])%mod;//最后一次运算要自己写因为不是幂运算
            }
            cout<<ans<<endl;
        }
    }
}
  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-25 11:31:44  更:2022-05-25 11:32:17 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 5:53:12-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码