加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

Divisibility by 25 CodeForces - 988E(模拟)

发布时间:2020-12-14 03:48:46 所属栏目:大数据 来源:网络整理
导读:?遇见模拟题 有两种做法 例如这题: 1、直接去算次数(统计哪个数在第几位,然后去运算) 2、模拟操作 贴一个别人的代码。。。https://blog.csdn.net/weixin_39453270/article/details/80548780 #include bits/stdc++.h using namespace std; const int INF= 0

?遇见模拟题 有两种做法 例如这题:

  1、直接去算次数(统计哪个数在第几位,然后去运算)

  2、模拟操作

贴一个别人的代码。。。https://blog.csdn.net/weixin_39453270/article/details/80548780

#include <bits/stdc++.h>
using namespace std;
const int INF=0x3f3f3f3f;
string str1,str2;
bool vis=0;
void Get(char a,char b,int n,int &ans){
    str2=str1;
    int cnt=0;
    int tmp=0;
    for(int i=n-1;i>=0;i--){//将最后一位置为字符b
        if(str2[i]==b){
            cnt++;
            for(int j=i;j<n-1;j++){
                swap(str2[j],str2[j+1]);
                tmp++;
            }
            break;
        }
    }
    for(int i=n-2;i>=0;i--){//将倒数第二位置为字符a
        if(str2[i]==a){
            cnt++;
            for(int j=i;j<n-2;j++){
                swap(str2[j],str2[j+1]);
                tmp++;
            }
            break;
        }
    }
    if(cnt==2){//如果能够构成后缀ab
        if(str2[0]!=0){
            vis=1;
            //cout<<tmp<<endl;
            ans=min(ans,tmp);
        }//如果有前导0
        else{
            for(int i=0;i<n-2;i++){
                if(str2[i]!=0){//从第1位到n-2位找到第一个不为0的数
                    tmp+=i;
                    vis=1;
                    ans=min(ans,tmp);
                    break;
                }
            }
        }
    }
}
int main()
{
    cin>>str1;
    int len=str1.length();
    int ans=INF;
    //四种情况贪心取最小
    Get(0,0,len,ans);
    Get(2,5,ans);
    Get(5,ans);
    Get(7,ans);
    if(vis) cout<<ans<<endl;
    else puts("-1");
    return 0;
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读