首页 > 代码库 > UVa 1583打表
UVa 1583打表
背景:1--TLE:超时,没有考虑到时间复杂度,开始对每一个数都从1开始到99999,这样就是O(t*key)这样20组大数就可以超时。2--WA:3--WA都是把数字误以为最多4位了,其实是五位!!!。
思路:找出i(从1到100000)产生的数n,i是n的生成元,由于最多5位数字相加,所以n-i<50.对于每个要找生成元的数t,如果t大于50,只需搜索(t-50,t)。
学习:1.对于所有情况最多10万级别的可以打表。
#include<stdio.h> int str[99999]; int main(void){ str[0]=0; for(int i=1;i<99999;i++){ int temp=i; str[i]=i; for(int j=0;j<5;j++){ str[i]+=temp%10; temp/=10; } } int t; scanf("%d",&t); while(t--){ int key,judege=0; scanf("%d",&key); for(int i=1;i<99999;i++){ if(i==1){ if(key>50) i=key-50; } if(str[i]==key){ judege=1; printf("%d\n",i); break; } } if(!judege) printf("0\n"); } return 0; }
UVa 1583打表
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。