求助!代码写一百多行写出个去"-"程序
查看原帖
求助!代码写一百多行写出个去"-"程序
379331
zhi0mx楼主2022/1/28 20:03
#include <iostream>
using namespace std;
int p1,p2,p3,n=0,pi;//n:“-”的个数;pi:当前遍历下标
string s,p[110];//p:“-”展开后的内容
int main()
{
    cin>>p1>>p2>>p3>>s;
    for (int i=0;i<s.length();i++)
    {
        if (s[i]=='-')
            if (s[i-1]<s[i+1] && (((s[i-1]>='a' && s[i-1]<='z') && (s[i+1]>='a' && s[i+1]<='z')) || ((s[i-1]>='0' && s[i-1]<='9') && (s[i-1]>='a' && s[i-1]<='z'))))
            {
                pi=0;//当前下标归零
                if (p1==1)
                {
                    if (p3==1)
                        for (char j=s[i-1]+1;j<s[i+1];j++)
                            for (int k=1;k<=p2;k++)
                            {
                                p[n][pi]=j;
                                pi++;
                            }
                    else
                        for (char j=s[i+1]-1;j>s[i-1];j--)
                            for (int k=1;k<=p2;k++)
                            {
                                p[n][pi]=j;
                                pi++;
                            }
                }
                if (p1==2)
                {
                    if ((s[i-1]>='a' && s[i-1]<='z') && (s[i+1]>='a' && s[i+1]<='z'))
                    {
                        if (p3==1)
                            for (char j=s[i-1]+1;j<s[i+1];j++)
                                for (int k=1;k<=p2;k++)
                                {
                                    p[n][pi]=j-'a'+'A';
                                    pi++;
                                }
                        else
                            for (char j=s[i+1]-1;j>s[i-1];j--)
                                for (int k=1;k<=p2;k++)
                                {
                                    p[n][pi]=j-'a'+'A';
                                    pi++;
                                }
                    }
                    else
                    {
                        if (p3==1)
                            for (char j=s[i-1]+1;j<s[i+1];j++)
                                for (int k=1;k<=p2;k++)
                                {
                                    p[n][pi]=j;
                                    pi++;
                                }
                        else
                            for (char j=s[i+1]-1;j>s[i-1];j--)
                                for (int k=1;k<=p2;k++)
                                {
                                    p[n][pi]=j;
                                    pi++;
                                }
                    }
                }
                if (p1==3)
                    for (char j=s[i-1]+1;j<s[i+1];j++)
                        for (int k=1;k<=p2;k++)
                        {
                            p[n][pi]='*';
                            pi++;
                        }
                n++;
            }
    }
    for (int i=0,j=0;i<s.length();i++)//j:当前遍历到的“-”个数
    {
        if (s[i]=='-')//将“-”替换成展开后的内容
        {
            cout<<p[j];
            j++;
        }
        else
        {
            cout<<s[i];
        }
    }
    return 0;
}
2022/1/28 20:03
加载中...