社区讨论

爆0求救

B4069[GESP202412 四级] 字符排序参与者 1已保存回复 1

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
1 条
当前快照
1 份
快照标识符
@mhj9dv2h
此快照首次捕获于
2025/11/03 22:52
4 个月前
此快照最后确认于
2025/11/03 22:52
4 个月前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
#define int long long
int T,n,a[101],b[101];
string s[101];
signed main(){
    cin>>T;
    while(T--){
        int f=0;
        cin>>n;
        for(int i=1;i<=n;i++){
            cin>>s[i];
            for(int j=1;j<s[i].size();j++){
                if(s[i][j]<s[i][j-1]) f=1;
            }
        }
        if(f==1){
            cout<<"0"<<endl;
            continue;
        }
        for(int i=1;i<=n;i++) a[i]=s[i][0]-'a'+1,b[i]=s[i][s[i].size()-1]-'a'+1;
        for(int i=1;i<n;i++){
            for(int j=1;j<=n-i;j++){
                if(a[j]>a[j+1]) swap(a[j],a[j+1]),swap(b[j],b[j+1]);
            }
        }
        for(int i=1;i<n;i++){
            if(b[i]>a[i+1]) f=1;
        }
        if(f==1) cout<<"0";
        else cout<<"1";
        cout<<endl;
    }
}
样例已过,别在下面发题解

回复

1 条回复,欢迎继续交流。

正在加载回复...