• 牛客周赛 Round 14


    A、

    小红拿到了一个环形字符串。所谓环形字符串,即首尾相连的字符串。

    小红每次可以删除两个相邻的相同字符。小红想知道,最多可以删除多少个字符?

    输入描述:

    第一行输入一个正整数n,代表环形字符串的长度。
    第二行输入一个长度为n,且仅由小写字母组成的字符串。请注意该字符串是首尾相连的。
    1≤n≤10^5

    输出描述:

    最多可以删除的字符数量。

    示例1

    输入

    5
    abcba

    输出

    4

     这个题很经典啊 我感觉以前一直不会

    思路:一个一个字符插进去  遇到和前一个一样  消去它们

    然后只能是首尾消去了

    1. #include<bits/stdc++.h>
    2. using namespace std;
    3. #define int long long
    4. #define fp(i,a,b) for(int i=a;i<=b;++i)
    5. #define PII pair<int,int>
    6. const int N=1e5+10;
    7. const int mod=1e9+7;
    8. const double eps=1e-5;
    9. typedef double db;
    10. string s;
    11. int n;
    12. list<char>q;
    13. signed main()
    14. {
    15. cin>>n>>s;
    16. int sum=0;
    17. for(int i=0;i<n;i++)
    18. {
    19. if(!q.empty())
    20. {
    21. if(q.back()==s[i])sum+=2,q.pop_back();
    22. else q.push_back(s[i]);
    23. }
    24. else
    25. {
    26. q.push_back(s[i]);
    27. }
    28. }
    29. while(q.size()>1&&q.front()==q.back()){
    30. sum+=2;
    31. q.pop_back();
    32. q.pop_front();
    33. }
    34. cout<<sum<<"\n";
    35. return 0;
    36. }
    37. //x*5n/6m=y
    38. //x*5n=y*6m
    39. //x/y=6m/5n

    B、

    题目描述

    小红拿到了一个正整数 x。她可以对 x 做以下操作:
    1. 将 x 乘以5。
    2. 若 x 是6的倍数,将 x 除以6。

    例如,12经过一次操作可以变成60,也可以变成2。

    现在小红想知道,如果要把 x 变成 y,需要操作多少次?一共有 t 组询问。

    输入描述:

    第一行输入一个正整数 t,代表询问次数。
    接下来的 t 行,每行输入两个正整数 x 和 y ,代表一次询问。
    数据范围:
    1≤t≤1000
    1≤x,y≤10^9

    输出描述:

    输出t行,对于每次询问,如果无论如何都不能把 x 变成 y,输出-1。否则输出操作次数。

    示例1

    输入

    1
    6 5

    输出

    2

    说明

    x除以6变为1,再乘5变为5,即操作2次可使x变为y
    
    1. #include<bits/stdc++.h>
    2. using namespace std;
    3. #define int long long
    4. #define fp(i,a,b) for(int i=a;i<=b;++i)
    5. #define PII pair<int,int>
    6. const int N=1e5+10;
    7. const int mod=1e9+7;
    8. const double eps=1e-5;
    9. typedef double db;
    10. signed main()
    11. {
    12. int t;
    13. cin>>t;
    14. while (t--) {
    15. int X,Y;
    16. cin>>X>>Y;
    17. int c5 = 0, c6=0, d5=0, d6=0;
    18. while (X%5==0) c5++, X/=5;
    19. while (X%6==0) c6++, X/=6;
    20. while (Y%5==0) d5++, Y/=5;
    21. while (Y%6==0) d6++, Y/=6;
    22. int ans;
    23. if (c5>d5||c6<d6|| X!=Y) ans=-1;
    24. else ans = d5-c5+c6-d6;
    25. cout<<ans<<"\n";
    26. }
    27. return 0;
    28. }

     

     这个是把x、y都溯源回本质 再进行判断。

    D、

    定义一个字符串的权值为:长度为3的回文子串的数量。
    求长度为n的、仅由小写字母组成的所有字符串的权值之和。答案对10^9+7取模。
    提示:共有26^n个字符串。

    输入描述:

    一个正整数n
    1≤n≤10^12

    输出描述:

    长度为n的所有字符串权值之和,对10^9+7取模的值。

    示例1

    输入

    3

    输出

    676

    说明

    长度为3的字符串中,有676个字符串的权值为1:aba、ovo等。

     先放代码。

    1. #include<bits/stdc++.h>
    2. using namespace std;
    3. #define int long long
    4. #define fp(i,a,b) for(int i=a;i<=b;++i)
    5. #define PII pair<int,int>
    6. const int N=1e5+10;
    7. const int mod=1e9+7;
    8. const double eps=1e-5;
    9. typedef double db;
    10. int qsm(int x,int n)
    11. {
    12. int res=1;
    13. while(n)
    14. {
    15. if(n&1)res=res*x%mod;
    16. x=x*x%mod;
    17. n>>=1;
    18. }
    19. return res;
    20. }
    21. signed main()
    22. {
    23. int n;
    24. cin>>n;
    25. if(n<3){
    26. cout<<0<<"\n";
    27. return 0;
    28. }
    29. int sum=(n-2)*26*26%mod*qsm(26,n-3)%mod;
    30. cout<<sum<<"\n";
    31. return 0;
    32. }

    n-2是我有这么多组可以平移 

    26*26 是一组的里面的数量

    qsm(26,n-3)是这一组3个字符以外 其他可以任选

    C我不会 以后有空看看能不能补 看到头疼

  • 相关阅读:
    使用 BERT 进行文本分类 (03/3)
    用10元,20元,50元三种币值的纸币凑出1000元,一共有多少种组合(C++实现)三种思路,两种实现
    工业控制系统面临的安全问题分析
    innovus:antenna设置
    机器学习——代价敏感错误率与代价曲线
    2022牛客多校(三)
    【Java技术专题】「Java8技术盲区」函数接口字典-看看还有哪些你所不知道函数接口
    图像分割(四)---(图像显示、灰度直方图和三维灰度图综合分析选取最佳分割方法)
    Google Chrome如何同步书签
    使用wget命令报错:Issued certificate has expired(颁发的证书已经过期)
  • 原文地址:https://blog.csdn.net/m0_61949623/article/details/133773943