2021寒——Acm做题总结1

1.P1017 [NOIP2000 提高组] 进制转换
题目链接
题意:
将一个十进制整数转换成相应的负进制数,比如-15的(-2)进制为110001((-2)0+(-2)4+(-2)*5)
解题思路:
除数=被除数x商+余数
但是余数可能是负数,因此我们要把它变成整数,即令余数-被除数,除数+被除数
证明如下:
除数=被除数想(商+1)+余数-被除数=被除数x商+余数
注意:
1.进制转换是逆序输出,因此要在递归函数之后输出
2.3+‘0’ 整数转字符类型
2.P1019 [NOIP2000 提高组] 单词接龙
题目链接
题意:
以给定的单词接龙,相邻的单词以最小相容段连接,每个单词不能超过2次
解题思路:
预处理函数(找出各个单词的最小相容段)+dfs
注意:
1.熟记这个预处理函数

int mt(int x, int y){//mt函数,返回x单词后连接一个y单词的最小重叠部分
    bool pp=true;
    int ky=0;
    for(int k=tr[x].size()-1;k>=0;k--){//从x单词尾部向前看看最小重叠部分是从哪里开始的,以为因为是倒着来,所以保证是最小的
        for(int kx=k;kx<tr[x].size();kx++){
            if(tr[x][kx]!=tr[y][ky++]){
                pp=false;
                break;//第二个for循环结束
            }
        }
        if(pp==true){//如果说当前以k为开头的前一个单词后缀 ,是后面单词的前缀,就马上返回重叠部分。(tr[x].size()-k是找出来的规律)
            return tr[x].size()-k;        }
        ky=0;
        pp=true;//不行就继续
    }
    return 0;
}

2.第一次字符串还能怎么用:
s【x】【y】:x是第几个字符串,也是给字符串的第y个字符
3.注意dfs的结束条件
3.P1020 [NOIP1999 普及组] 导弹拦截
题目链接
解题思路:
经典的最长上升子段数(推荐一个优质博客)
但是这样仅仅时间复杂度只能是O(n2),优化采用stl的low/up

for(int i=2;i<=n;i++)
	if(d[len]>=a[i])d[++len]=a[i];
	else {
		int p=upper_bound(d+1,d+1+len,a[i],greater<int>())-d;
		d[p]=a[i];
	}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

沉梦昂志️

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值