怎么错了
查看原帖
怎么错了
373979
efgh123楼主2020/11/20 19: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;
}

样例对了

2020/11/20 19:38
加载中...