C++算法篇

目的

主要是积累一些常用有效算法,希望有能帮助大家, 后期会多多补充。

实例

1: 不用新变量,实现两个变量交换值

1: 加法
a= a+b;
b= a-b;
a=a-b;
2:^
a=a^b;
b=a^b;
a=a^b;

2: 不用加减乘除实现加法

int add(int num1, int num2)
{
	int sum, carry;
	do
	{
		sum = num1 ^ num2;
		carry = (num1 & num2) << 1;
		num1 = sum;
		num2 = carry;
    }while(num2 != 0);
    return num1;
}
//思想 以十进制加法思路来推演,第一步,不考虑进位进行加法运算, 第二步,考虑加法计算后的进位运算,第三步,将前两个步骤过程进行加法运算, 将重复前两步过程 直到不在产生进位。
  1. 判断数值是几位数
    主要是为了记录判断数值是几位数的算法, 希望能给你带来帮助
    3.1 常用循环法-除法
int digitNum(const int& num)
{
   int len = 0;
   do
   {
     ++len ;
     num = num/10;
    }while(num)
    return len ;
}

可读性强, 主要是性能方面有所损耗(做了除法).

3.2 数值除掉正负,转字符串, 查看字符串的个数。

  1. 判断数值有几个1
    常用循环法- 减一,&
template <typename T>
int bits(T num)
{
  const int max = std::numeric_limits<T>().digits;  //获取数据类型最大位数
  int digits = 0;
  while (digits <= max && num != 0)
  {
    num &= num - 1;
    ++digits;
  }
  return digits;
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

道阻且长,行则降至

无聊,打赏求刺激而已

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

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

打赏作者

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

抵扣说明:

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

余额充值