琐碎的一点技巧

用迭代器对整个数组做一次遍历

for (auto &it:a) //后面跟操作,这样就不用写迭代器的定义了

求出数组中最小的值,就不用写循环了

int arr[5]={1,2,3,4,5};
int k=*max_element(arr,arr+5);	//输出5
k=*min_element(arr,arr+5);		//输出1

从数组的地址中获得下标

//就比如min_element会返回地址,以2为例
int pla=max_element(arr,arr+5)-arr;
//其实讲指针的时候应该都学过,但是这个挺常用的

多组数据输入,都为0时退出的正确写法

while (scanf("%d%d%d%d",&n,&m,&l,&r) !=EOF &&(n||m||l||r) )

对于一个环,前进n步与后退n步的正确写法

//前进,默认起点为a,环的总长为m
int front=(a+n)%m; //毕竟都是正的,
//后退,两种写法,写法1更严谨一点
int back=((a-n)%m+m)%m; 
int back=(a-n+m)%m;//如果n故意写的很大,得出的下标会是负值

结构体的初始化

struct node{
	int val;
	node *l,*r;
	node (int val=0,node *l=NULL,node *r=NULL):val(val),l(l),r(r){}
};

string 的大小写转换

transform(b.begin(),b.end(),b.begin(),::tolower);//小写化

判断一个数是否为2的幂

int i;
int tem=i&(i-1);
if(tem==0)
    cout<<"YES";
posted @ 2020-03-14 18:29  Salty_Fish  阅读(185)  评论(0编辑  收藏  举报