算法刷题小技巧

1.4604. 集合询问

利用二进制---->判断该数每个数位的奇偶性

询问操作:如果 s的第 i位为 0,则 x 的第 i位必须为偶数,如果 s的第 i位为 1,则 x的第 i位必须为奇数。

scanf("%s",str);
int x=0;
for(int i=0;str[i];i++)
   x=x*2+str[i]%2;//x*2表示跳到x的二进制表示下一位,str[i]%2表示判断该位的奇偶性

2.2005. 马蹄铁

利用向量偏移量----->坐标的上下左右移动 

 int dx[4] = {-1, 0, 1, 0}, dy[4] = {0, 1, 0, -1};//表示坐标偏移量:上下左右
 for (int i = 0; i < 4; i++)
 {
    int a = x + dx[i], b = y + dy[i];
 }
                        

3.4872. 最短路之和 

在图中删点不好做,逆向思维,把点一个一个加入图中

4.邻接表一定要记得初始化!!!!


int h[N], w[M], e[M], ne[M], idx;
memset(h,-1,sizeof h);

5.C++ 保留N位小数的方法

#include <iomanip>
...
cout<<fixed<<setprecision(n)<<shu; //shu就是你要保留小数的数字;n为保留小数的位数
...

6.两数相减可能为正,可能为负------>通过取模统一化为正

((a-b)+n)%n

7.判断序列中该数出现的次数

if(upper_bound(a+1,a+n+1,a[i])-lower_bound(a+1,a+n+1,a[i])<=n)//二分求个数
//n为出现的次数

  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值