本周的学习就是对以前知识的回顾,在这期间,主要是复习了回文数、素数、结构体,还有他们之间灵活运用。至于其他的如DFS等,接下来找出时间进行回顾复习练习,尽力以达到熟练的地步。
经过这一周的学习,我深刻意识到自己知识上的匮乏以及对题目的缺乏更深层次的理解,这也就导致了做题的局限和手足无措,明明是自己学过的,用过的知识,却是无法联系到题目上,这其中当然是缺乏大量的训练。
在此, 本学期,就是对知识的大量摄入,以及对题目的大量练习,应该就能有明显的进步。
另外,在此次学习中,也延伸到了质数筛法,但由于没用的时间长,对于它的理解还是有点难
//欧氏筛法(线性筛法)
int prime[N],cnt=0;
bool st[N]={false};
//算法核心:x仅会被其最小质因子筛去
void get_prime(int x) {
for(int i = 2; i <= x; i++) {
if(!st[i]) prime[cnt++] = i;
for(int j = 0; prime[j] <= x / i; j++) {
//对于任意一个合数x,假设pj为x最小质因子,当i<x/pj时,一定会被筛掉
st[prime[j]*i] = true;
if(i % prime[j] == 0) break;
/*pj是prime[j]的缩写
1.i%pj == 0, pj定为i最小质因子,pj也定为pj*i最小质因子
2.i%pj != 0, pj定小于i的所有质因子,所以pj也为pj*i最小质因子
*/
}
}
}