一个复杂度较低的算法,供参考
查看原帖
一个复杂度较低的算法,供参考
1491978
helpmeplease楼主2024/11/4 16:34
#include<bits/stdc++.h>  
using namespace std;
int main(){
	int k;
	string a;
	cin>>a>>k;
	int n=a.size();
	long int N=0,t=1;
	for(int i=n-1;i>=0;i--){
		N+=(a[i]-'0')*t;
		t*=10;
	}
	int sum=0;
	if(k==0){
		for(int i=0;i<n;i++){
			sum+=(N/t-1)*t/10;
			if(a[i]-'0'==k){
				sum=sum+N%(t/10)+1;	
			}else if(a[i]-'0'>k){
				sum+=(t/10);
			}
			t/=10;
		}
        cout<<sum;
        return 0;
	}
	for(int i=0;i<n;i++){
		sum+=N/t*t/10;
		if(a[i]-'0'==k){
			sum=sum+N%(t/10)+1;	
		}else if(a[i]-'0'>k){
			sum+=(t/10);
		}
		t/=10;
	}
	cout<<sum;	
	return 0;
 }
2024/11/4 16:34
加载中...