怎么错了

P1591 阶乘数码

efgh123 @ 2020-11-20 19:38:38

#include<bits/stdc++.h>
using namespace std;
int compare(string str1,string str2)
{
    if(str1.length()>str2.length()) return 1;
    else if(str1.length()<str2.length())  return -1;
    else return str1.compare(str2);
}
string add(string str1,string str2)
{
    string str;
    int len1=str1.length();
    int len2=str2.length();
    if(len1<len2)
    {
        for(int i=1;i<=len2-len1;i++)
           str1="0"+str1;
    }
    else
    {
        for(int i=1;i<=len1-len2;i++)
           str2="0"+str2;
    }
    len1=str1.length();
    int cf=0;
    int temp;
    for(int i=len1-1;i>=0;i--)
    {
        temp=str1[i]-'0'+str2[i]-'0'+cf;
        cf=temp/10;
        temp%=10;
        str=char(temp+'0')+str;
    }
    if(cf!=0)  str=char(cf+'0')+str;
    return str;
}
string sub(string str1,string str2)
{
    string str;
    int tmp=str1.length()-str2.length();
    int cf=0;
    for(int i=str2.length()-1;i>=0;i--)
    {
        if(str1[tmp+i]<str2[i]+cf)
        {
            str=char(str1[tmp+i]-str2[i]-cf+'0'+10)+str;
            cf=1;
        }
        else
        {
            str=char(str1[tmp+i]-str2[i]-cf+'0')+str;
            cf=0;
        }
    }
    for(int i=tmp-1;i>=0;i--)
    {
        if(str1[i]-cf>='0')
        {
            str=char(str1[i]-cf)+str;
            cf=0;
        }
        else
        {
            str=char(str1[i]-cf+10)+str;
            cf=1;
        }
    }
    str.erase(0,str.find_first_not_of('0'));
    return str;
}
string mul(string str1,string str2)
{
    string str;
    int len1=str1.length();
    int len2=str2.length();
    string tempstr;
    for(int i=len2-1;i>=0;i--)
    {
        tempstr="";
        int temp=str2[i]-'0';
        int t=0;
        int cf=0;
        if(temp!=0)
        {
            for(int j=1;j<=len2-1-i;j++)
              tempstr+="0";
            for(int j=len1-1;j>=0;j--)
            {
                t=(temp*(str1[j]-'0')+cf)%10;
                cf=(temp*(str1[j]-'0')+cf)/10;
                tempstr=char(t+'0')+tempstr;
            }
            if(cf!=0) tempstr=char(cf+'0')+tempstr;
        }
        str=add(str,tempstr);
    }
    str.erase(0,str.find_first_not_of('0'));
    return str;
}
string operator+(string a,string b){
    if(a[0]=='-'&&b[0]=='-')
    {
    string an,bn;
    for(int i=1;i<a.length();i++)an+=a[i];
    for(int i=1;i<b.length();i++)bn+=b[i];
    if("-"+add(an,bn)=="-0"||"-"+add(an,bn)=="-"||"-"+add(an,bn)=="")return "0";
    return "-"+add(an,bn);
    }
    if(a[0]=='-'&&b[0]!='-'){
        string an,bn;
        for(int i=1;i<a.length();i++)an+=a[i];
        if(compare(an,b)==1){
            if("-"+sub(an,b)=="-0"||"-"+sub(an,b)=="-"||"-"+sub(an,b)=="")return "0";
            return "-"+sub(an,b);
        }
        if(sub(b,an)=="-0"||sub(b,an)=="-"||sub(b,an)=="")return "0";
        return sub(b,an);
    }
    if(a[0]!='-'&&b[0]=='-'){
        string an,bn;
        for(int i=1;i<b.length();i++)bn+=b[i];
        if(compare(a,bn)==1){
            if(sub(a,bn)=="-0"||sub(a,bn)=="-"||sub(a,bn)=="")return "0";
            return sub(a,bn);
    }
        if("-"+sub(bn,a)=="-0"||"-"+sub(bn,a)=="-"||"-"+sub(bn,a)=="")return "0";
        return "-"+sub(bn,a);
    }
    return add(a,b);
}
string operator-(string a,string b){
    if(a==b)return "0";
    if(compare(a,b)==1){
    return sub(a,b);
    }
    return "-"+sub(b,a);
}
string operator*(string a,string b){
    if(a[0]=='-'||b[0]=='-'){
    if(a[0]=='-'&&b[0]=='-'){
        string an,bn;
        for(int i=1;i<a.length();i++)an+=a[i];
        for(int i=1;i<b.length();i++)bn+=b[i];
        if(mul(an,bn)=="")return "0";
        return mul(an,bn);
    }
    if(a[0]=='-'&&b[0]!='-'){
        string an,bn;
        for(int i=1;i<a.length();i++)an+=a[i];
        if("-"+mul(an,b)=="-")return "0";
        return "-"+mul(an,b);
    }
    if(a[0]!='-'&&b[0]=='-'){
        string an,bn;
        for(int i=1;i<b.length();i++)bn+=b[i];
        if("-"+mul(a,bn)=="-")return "0";
        return "-"+mul(a,bn);
    }
    }
    if(mul(a,b)=="")return "0";
    return mul(a,b);
}
int main(){
    int t;
    cin>>t;
    for(int k=0;k<t;k++){
    int a;
    cin>>a;
    string num="1";
    for(long long i=a;i>0;i--){
        string in;
        in=char(i+'0');
        num=num*in;
    }
    char p;
    cin>>p;
    long long sum=0;
    for(long long i=0;i<num.length();i++){
        if(num[i]==p)sum++;
    }
    cout<<sum<<"\n";
    }
    return 0;
}

样例对了


by 精神小伙233 @ 2020-11-20 20:40:14

.....


|