【记录贴】ACM入门day3

题目:P1422 小玉家的电费

总结:cout << fixed<< setprecision(1); 会使后面所有输出精确到1位小数

题目:P1424 小鱼的航程(改进版)

总结:分类条件for循环

题目:P1888 三角函数

总结:

最大公约数GCD(Greatest Common Divisor)

最常见的求两个数的最大公约数的算法是辗转相除法,也叫欧几里得算法

该算法的c++语言实现如下:

#include<iostream>
using namespace std;
int gcd(int a,int b){
    return b==0?a:gcd(b,a%b);
}
int main(){
    int a=45,b=10;
    cout<<gcd(10,45);
}

例子:

最小公倍数LCM(Lowest Common Multiple)

最大公倍数=a*b/最大公约数;

它的c++语言实现如下:

#include<iostream>
using namespace std;
int gcd(int a,int b){
    return b==0?a:gcd(b,a%b);
}
int lcm(int a,int b){
 	return a*b/gcd(a,b);
}
int main(){
    int a=45,b=10;
    cout<<gcd(10,45)<<endl;
    cout<<lcm(10,45);
    return 0;
}

题目:P1046 [NOIP2005 普及组] 陶陶摘苹果

题目:P5717 【深基3.习8】三角形分类

总结:考虑问题要全面!!

题目:P4414 [COCI2006-2007#2] ABC

总结:有字母可以用ascii码化简代码

【入门3】循环结构

题目:P5718 【深基4.例2】找最小值

题目:P5719 【深基4.例3】分类平均

题目:P5720 【深基4.例4】一尺之棰

总结:

// 将二进制位向右移动一位
		n >>= 1;

位移运算

<<运算

a<<b 表示把a转为二进制后左移b位(在后面添加 b个0)。例如100的二进制表示为1100100,100左移2位后(后面加2个零):1100100<<2 =110010000 =400,可以看出,a<<b的值实际上就是a乘以2的b次方,因为在二进制数后面添加一个0就相当该数乘以2,2个零即2的2次方 等于4。通常认为a<<1比a*2更快,因为前者是更底层一些的操作。因此程序中乘以2的操作尽量用左移一位来代替。

定义一些常量可能会用到<<运算。你可以方便的用1<<16 -1 来表示65535(unsingned int  最大值16位系统)。很多算法数据结构要求数据模块必须是2的幂,此时就可以用<<来定义MAX_N等常量。

>>运算

和<<相似,a>>b表示二进制右移b位(去掉末b位),相当于a除以2的b次方(取整)我们经常用>>1来代替 /2(div 2),比如二分查找、堆的插入操作等等。想办法用>>代替除法运算可以使程序的效率大大提高。最大公约数的二进制算法用除以2操作来代替慢的出奇的%(mod)运算,效率可以提高60%。

int a =100;

a/4 ==a>>2;

题目:P5721 【深基4.例6】数字直角三角形

总结:找代码重复部分化简

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值