L. Digit sum (ICPC 2019 上海网络赛)

L. Digit sum (ICPC 2019 上海网络赛)

这题。。

L. Digit sum (ICPC 2019 上海网络赛)

题意好像就是把一个数n转化为b进制,然后从n=1开始,一直加到这个数的二进制的位数的和。然后我想到函数库#include<stdlib.h>里面一个求进制的函数itoa,然后打出来了,测试的时候发现,这个oj评判系统竟然没有这个函数,无奈自己只能自己写,然后就是下面这个

#include<bits/stdc++.h>
using namespace std;
const int maxn = 1e6 + 10;
char str[maxn];
char *itoa_my(int value,char *string,int radix)
{
	char zm[37]="0123456789abcdefghijklmnopqrstuvwxyz";
	char aa[100]={0};
 
	int sum=value;
	char *cp=string;
	int i=0;
	
	if(radix<2||radix>36)
	{
		cout<<"error data!"<<endl;
		return string;
	}
 
	if(value<0)
	{
		cout<<"error data!"<<endl;
		return string;
	}
	
 
	while(sum>0)
	{
		aa[i++]=zm[sum%radix];
		sum/=radix;
	}
 
	for(int j=i-1;j>=0;j--)
	{
		*cp++=aa[j];
	}
	*cp='\0';
	return string;
}
int shuhe(int n,int b)
{
	int sum = 0;
	itoa_my( n, str, b );
	int h = strlen(str);
	for(int i=0;i<h;i++)
	{
			sum+=str[i]-'0';
	}	
	return sum;
} 
int main()
{
	int t, n, b;
	scanf("%d",&t);
	for(int j = 1;j<=t;j++ )
	{
		int ans=0;
		scanf("%d%d",&n,&b);
		for(int i=1;i<=n;i++)
		{
			ans += shuhe(i,b);
		}
		
		cout<<"Case #"<<j<<": "<<ans<<endl;
	}
}

样例啥的都没问题,就是超时,然后超时你要超多点,也就算了,然后题目要求是2000ms我这是2010到2030ms就超那么一点

然后,一直过不去,然后我们队就我一个做,实在不想怼了。这个超了12ms,,,。

然后网上的题解是这样的 

思路:二维树状数组+区间求和

 

#include<iostream>
using namespace std;
const int MAXN = 1000001;
int c[11][MAXN];
int calc(int n,int b)
{
	int res=0;
	while(n)
	{
		res += (n%b);
		n/=b;
	}
	return res;
}
int lowbit(int x)
{
	return x&(-x);
}
void add(int x,int y,int val)
{
	while(y<MAXN)
	{
		c[x][y]+=val;
		y+=lowbit(y);
	}
}
int Sum(int x,int y)
{
	int sum = 0;
	while(y>0)
	{
		sum+=c[x][y];
		y-=lowbit(y);
	}
	return sum;
}
void init() //将二到十进制的所有数的情况计算出来,且对每个进制建立一个树状数组 
{
	for(int i=2;i<=10;i++)
	{
		for(int j=1;j<MAXN;j++)
		{
			int val = calc(j,i);
			add(i,j,val);
		}
	}
}
int main()
{
	int T,id=1;
	init();
	scanf("%d",&T);
	while(T--)
	{
		int n,b;
		scanf("%d%d",&n,&b);
		printf("Case #%d: %d\n",id++,Sum(b,n));
	}
	return 0;
}

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/114853.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • s3cmd命令_cmd常用命令详解

    s3cmd命令_cmd常用命令详解s3cmd(1)s3cmd(1)NAMEs3cmd-toolformanagingAmazonS3storagespaceandAmazonCloudFrontcontentdeliverynetworkSYNO

    2022年10月21日
    0
  • A股和B股的区别_b股是什么股票

    A股和B股的区别_b股是什么股票A股:正式名称是人民币普通股票。它是由我同境内的公司发行,供境内机构、组织或个人(不含台、港、澳投资者)以人民币认购和交易的普通股股票,我国A股股票市场经过几年快速发展,已经初具规模。.B股:正式名

    2022年8月2日
    8
  • python中保留小数的方法_保留一位小数怎么保留

    python中保留小数的方法_保留一位小数怎么保留Python保留小数的几种方法1.使用字符串格式化print(“%.2f”%a)2.使用round内置函数round(num,2)3.使用Decimal模块fromdecimalimpotDecimala=12.314Decimal(a).quantize(Decimal(“0.00”))转载于:https://www.cnblogs.com/z…

    2022年8月12日
    2
  • Java构造方法(超详细!)

    Java构造方法(超详细!)1.构造方法有什么作用?构造方法是一个比较特殊的方法,通过构造方法可以完成对象的创建,以及实例变量的初始化。换句话说:构造方法是用来创建对象,并且同时给对象的属性赋值。注意:实例变量没有手动赋值的时候,系统会赋默认值。2.构造方法怎么定义,语法是什么?[修饰符列表]构造方法名(形式参数列表){ 构造方法体; 通常在构造方法体当中给属性赋值,完成属性的初始化。}注意:第一:修饰符列表目前统一写:public。千万不要写publicstatic。第二:构造方法名和类名必须一致。第

    2022年7月7日
    21
  • CF B. Kolya and Tandem Repeat

    CF B. Kolya and Tandem Repeat

    2022年2月5日
    81
  • 实现财务自由之路_程序员的个人财富课

    实现财务自由之路_程序员的个人财富课给自己设定一个目标

    2022年10月7日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号