数字(加强版)

思路:一开始是按照题目意思做,发现tle了,于是用数学方法,发现题目中说数码和不超过10的六次方,那么可以联系上数码和,发现ans=不等于0的位数个数+数码和,但如果n[len-1]!=0时,先把它化为1再消0就可以节约一步

原代码

复制代码
#include<stdio.h>
#include<string.h>
void cz1(int len,char n[]){
    char temp[10005];
    n[len-1]=n[len-1]-1;
}//减去1,默认n[len-1]>0
void cz2(int len,char n[]){
    char temp[10005];
    int cnt=0;
    for(int i=0;i<len;i++){
        if(n[i]!='0'){
            temp[cnt++]=n[i];
        }
    }
    temp[cnt]='\0';
    strcpy(n,temp);
}//消去0
int main(){
    int T;
    scanf("%d",&T);
    while(T--){
        char n[10005];
        scanf("%s",n);
        int cnt=0;
        while(n[0]!='0'){
            int len=strlen(n);
            if(n[len-1]=='0'){
                cz2(len,n);
            }else{
                cz1(len,n);
            }
            cnt++;
        }
        printf("%d\n",cnt);
    }
}

AC代码

复制代码
#include<stdio.h>
#include<string.h>

int main(){
	int T;
	scanf("%d",&T);
	while(T--){
		char n[10005];
		scanf("%s",n);
		long long cnt=0;
		int len=strlen(n);
		long long sum=0;
		for(int i=0;i<len;i++){
			if(n[i]!='0'){
				cnt++;
				long long t=n[i]-'0';
				sum+=t;
			}
		}
		long long ans=cnt+sum;
		if(n[len-1]!='0')ans--;
		printf("%lld\n",ans);
	}
}
相关推荐
a程序小傲5 小时前
京东Java面试被问:动态规划的状态压缩和优化技巧
java·开发语言·mysql·算法·adb·postgresql·深度优先
自学不成才5 小时前
深度复盘:一次flutter应用基于内存取证的黑盒加密破解实录并完善算法推理助手
c++·python·算法·数据挖掘
June`6 小时前
全排列与子集算法精解
算法·leetcode·深度优先
徐先生 @_@|||6 小时前
Palantir Foundry 五层架构模型详解
开发语言·python·深度学习·算法·机器学习·架构
夏鹏今天学习了吗7 小时前
【LeetCode热题100(78/100)】爬楼梯
算法·leetcode·职场和发展
m0_748250038 小时前
C++ 信号处理
c++·算法·信号处理
Ro Jace8 小时前
电子侦察信号处理流程及常用算法
算法·信号处理
yuyanjingtao8 小时前
动态规划 背包 之 凑钱
c++·算法·青少年编程·动态规划·gesp·csp-j/s
core5129 小时前
SGD 算法详解:蒙眼下山的寻宝者
人工智能·算法·矩阵分解·sgd·目标函数