CSP-S 2023
T1
直接 \(10^{5}\) 枚举状态就过了,合法的非零差分数量只可能为 \(1,2\)(\(0\) 相当于没转,按照题意 “都不是正确密码” 是不符的)
需要注意的是形如 0 9 1 1 1 -> 1 0 1 1 1 这样的合法状态
#include<bits/stdc++.h>
using namespace std;
int n;
int a[10][9];
int p[6];
bool check(int id){
	int r[6];
	int cnt=0;
	for(int i=1;i<=5;++i){
		r[i]=a[id][i]-p[i];
        while(r[i]<0) r[i]+=10;
	}
	for(int i=1;i<=5;++i){
		if(r[i]!=0){
            cnt++;
        }
	}
    /*
    1 9
    9 7
    8 -2
    8 6
    7 -3
    */
	if(cnt==1){
		return true;
	}
	else if(cnt==2){
		for(int i=1;i<=4;++i){
			if(r[i]!=0 and r[i+1]==r[i]){
				return true;
			}
		}
		return false;
	}
	return false;
}
int main(){
    //freopen("lock.in","r",stdin);
    //freopen("lock.out","w",stdout);
	cin>>n;
	for(int i=1;i<=n;++i){
		for(int j=1;j<=5;++j){
			cin>>a[i][j];
		}
	}
	int ans=0;
	for(p[1]=0;p[1]<=9;++p[1]){
		for(p[2]=0;p[2]<=9;++p[2]){
			for(p[3]=0;p[3]<=9;++p[3]){
				for(p[4]=0;p[4]<=9;++p[4]){
					for(p[5]=0;p[5]<=9;++p[5]){
						bool can=true;
						for(int i=1;i<=n;++i){
							if(!check(i)){
								can=false;
								break;
							}
						}
						if(can) ans++;
					}
				}
			}
		}
	}
//	cout<<cnt1<<" "<<cnt2<<endl;
	cout<<ans<<endl;
}
T2
首先能想到一个 \(O(n)\) 的 check(),就是开一个栈遍历,入栈时判断栈顶元素与放入元素能不能消,能消就消掉,最后判断栈是否非空
由此想到 \(n^{2}\) 做法,枚举开头,做 \(n\) 次 check,每当栈空就统计一次答案
由此想到 \(n\log n\) 做法,考虑只对整体 check() 一次,假如 \(i\neq j\),但 \(i,j\) 处栈的状态相同,那么就可以知道 \(i,j\) 之间的元素一定是可消除的,推广,假设有 \(k\) 个栈状态相同,对答案的贡献就是 \(\frac{k(k-1)}{2}\)
因此想到哈希,但是我一开始用的是异或哈希只有 20pts,想了一下发现异或哈希有交换律,会被 abab 这样的数据卡掉
直接普通哈希即可. 我看到题解区还有矩阵乘法的构造方法,总之选择的哈希算法无交换律就行
然后因为每次计算哈希值都从头计算,导致有一个 \(n^{2}\log n\) 的神奇复杂度过了 90pts,然后被随机数据卡了(因为随机数据的匹配值太小,导致栈里元素总是多的,会拉高复杂度)
实际上可以这么转移:
- 栈空 \(h_{i}=s_{i}\)
- 配对 \(h_{i}=h_{lst_{top}}\),\(lst_{top}\) 是栈顶元素的前一个元素
- 未匹配,\(h_{i}=h_{top}*num+s_{i}\),注意这里应该是 \(h_{top}\) 而不是 \(h_{i-1}\),因为上一个元素可能被弹出去了
#include<bits/stdc++.h>
using namespace std;
#define endl '\n'
template<typename T>
void read(T& x){
	x=0;bool sym=0;char c=getchar();
    while(!isdigit(c)){sym^=(c=='-');c=getchar();}
    while(isdigit(c)){x=x*10+c-48;c=getchar();}
    if(sym)x=-x;
}
template<typename T,typename... Args>
void read(T& x,Args&... args){
    read(x);read(args...);
}
int n;
string s;
inline unsigned long long _hash(stack<long long> st){
	unsigned long long res=0;
	while(!st.empty()){
		res=res*233ull+st.top();
		st.pop();
	}
	return res;
}
struct node{
	char num;
	int pla;
};
stack<node>st;
unordered_map<unsigned long long,long long>mp;
unsigned long long __hash[2000001];
int main(){
//	freopen("P9753_11.in","r",stdin);
	cin>>n>>s;
	s='?'+s;
	mp[0]++;
	__hash[0]=0;
	for(int i=1;i<=n;++i){
		if(st.empty()){
			st.push({s[i],i});
			__hash[i]=s[i];
			mp[__hash[i]]++;
		}
		else if(st.top().num==s[i]){
			__hash[i]=__hash[st.top().pla-1];
			st.pop();
			mp[__hash[i]]++;
		}
		else{
			__hash[i]=(__hash[st.top().pla]*233ull+s[i]);
			st.push({s[i],i});
			mp[__hash[i]]++;
		}
//		cout<<__hash[i]<<endl;
	}
	long long ans=0;
	for(auto i:mp){
//		cout<<i.second<<endl;
		ans+=((i.second)*(i.second-1))/2;
	}
	cout<<ans<<endl;
}
T3
他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟他妈的谁放的大模拟
- 末端 \(addr=\) 首位 \(addr+size\large{-1}\),5pts
- 考虑没声明就问你的情况,这样的情况会在操作 \(4\) 中出现,15pts
- 注意结构体的对齐,不是根据 \(totsize\),而是 \(\max\{subsize\}\),25pts
- 结构体内部元素是按照内部元素对齐方式对齐,而不是按照结构体对齐方式对齐,也就是 \(totsize\) 可能并不等于 \(k\times \max\{subsize\}\),65pts
- 一些奇奇怪怪的变量问题,100pts
耗费了下午一+下午二+晚新闻+晚一+晚二+晚三/2=250min
因为这个模拟比较小所以没写注释,你们不要学这种坏习惯,否则有概率导致忘掉自己写的是什么导致需要重新打
#include<bits/stdc++.h>
using namespace std;
#define int long long
#define type_byte 1
#define type_short 2
#define type_int 4
#define type_long 8
#define type_stru 9
ofstream cth;
struct stru{
	map<string,int>mem_id;
	map<int,string>mem_name;
	vector<int>mem_type;
	vector<int>mem_size;
	map<int,int>str_mem_id;
	vector<int>mem_addr;
	int cnt=-1;
	int maxsize,totsize,totaddr=0;
};
vector<stru>str;
vector<int>address;
map<string,int>str_id;
int now_address=0;
int cnt=-1,strcnt=-1;
vector<bool>isstr;
map<string,int>id;
map<int,string>name;
vector<int>str_reflect_id;
vector<int>sizeall;
int add_new(string _name,int size,bool _isstr,int reflect_id){
	if(_isstr) while(now_address%str[reflect_id].maxsize!=0) now_address++;
	else while(now_address%size!=0) now_address++;
	id[_name]=++cnt;
	name[cnt]=_name;
	address.push_back(now_address);
	int res=now_address;
	now_address+=size;
	isstr.push_back(_isstr);
	str_reflect_id.push_back(reflect_id);
	sizeall.push_back(size);
	return res;
}
namespace operation1{
	int mem_add_new(int strid,int size,int _isstr,int totsize){
//		if(str[strid].totaddr!=0) str[strid].totaddr++;
		while(str[strid].totaddr%size!=0) str[strid].totaddr++;
//		cth<<"[struct] new var from "<<str[strid].totaddr<<endl;//" to "<<str[strid].totaddr+totsize-1<<endl;
		int res=str[strid].totaddr;
		str[strid].totaddr+=totsize;
		return res;
	}
	void fixed_size(int strid,int masxsize){
		while(str[strid].totaddr%masxsize!=0) str[strid].totaddr++;
	}
	void act(){
		int k;string name;
		cin>>name>>k;
//		cth<<"new struct "<<name<<" ["<<k<<"]"<<endl;
		str.push_back({});strcnt++;
		str_id[name]=strcnt;
		for(int i=1;i<=k;++i){
			string type_name,_name;
			cin>>type_name>>_name;
			str[strcnt].mem_id[_name]=++str[strcnt].cnt;
			str[strcnt].mem_name[str[strcnt].cnt]=_name;
//			cth<<"["<<type_name<<"]";
			if(type_name=="byte"){
				str[strcnt].mem_type.push_back(type_byte);
				str[strcnt].mem_size.push_back(type_byte);
				str[strcnt].mem_addr.push_back(mem_add_new(strcnt,type_byte,false,type_byte));
			}
			else if(type_name=="short"){
				str[strcnt].mem_type.push_back(type_short);
				str[strcnt].mem_size.push_back(type_short);
				str[strcnt].mem_addr.push_back(mem_add_new(strcnt,type_short,false,type_short));
			}
			else if(type_name=="int"){
				str[strcnt].mem_type.push_back(type_int);
				str[strcnt].mem_size.push_back(type_int);
				str[strcnt].mem_addr.push_back(mem_add_new(strcnt,type_int,false,type_int));
			}
			else if(type_name=="long"){
				str[strcnt].mem_type.push_back(type_long);
				str[strcnt].mem_size.push_back(type_long);
				str[strcnt].mem_addr.push_back(mem_add_new(strcnt,type_long,false,type_long));
			}
			else{
				str[strcnt].mem_type.push_back(type_stru);
				str[strcnt].mem_size.push_back(str[str_id[type_name]].maxsize);
				str[strcnt].str_mem_id[i-1]=str_id[type_name];
				str[strcnt].mem_addr.push_back(mem_add_new(strcnt,str[str_id[type_name]].maxsize,true,str[str_id[type_name]].totsize));
			}
			str[strcnt].maxsize=max(str[strcnt].maxsize,str[strcnt].mem_size.back());
		}
		fixed_size(strcnt,str[strcnt].maxsize);
		str[strcnt].totsize=str[strcnt].totaddr;
		cout<<str[strcnt].totsize<<" "<<str[strcnt].maxsize<<endl;
//		cth<<"struct end: totsize["<<str[strcnt].totsize<<"]"<<endl;
	}
}
namespace operation2{
	void act(){
		string type_name,_name;
		cin>>type_name>>_name;
		if(type_name=="byte"){
			cout<<add_new(_name,type_byte,false,-1)<<endl;
		}
		else if(type_name=="short"){
			cout<<add_new(_name,type_short,false,-1)<<endl;
		}
		else if(type_name=="int"){
			cout<<add_new(_name,type_int,false,-1)<<endl;
		}
		else if(type_name=="long"){
			cout<<add_new(_name,type_long,false,-1)<<endl;
		}
		else{
//			cout<<"gogogogogo "<<_name<<" "<<str_id[type_name]<<endl;
			cout<<add_new(_name,str[str_id[type_name]].totsize,true,str_id[type_name])<<endl;
		}
//		cth<<"[struct] new var from "<<address[cnt]<<endl;
		//cth<<"new var "<<type_name<<" '"<<_name<<"' in address "<<address[cnt]<<" to "<<address[cnt]+sizeall[cnt]-1<<endl;
	}
}
namespace operation3{
	int judge_remain(int strid,string remain){
//		cout<<"judge remain "<<" "<<strid<<" "<<remain<<endl;
		if(remain.empty()) return 0;
		int i=0;string nam,rem;
		for(i=0;i<=(int)remain.length()-1;++i){
			if(remain[i]=='.'){
				break;
			}
			nam.push_back(remain[i]);
		}
		for(i++;i<=(int)remain.length()-1;++i){
			rem.push_back(remain[i]);
		}
//		cout<<"tyope ";
//		for(int i:str[strid].mem_type) cout<<i<<" ";
//		cout<<endl;
		if(str[strid].mem_type[str[strid].mem_id[nam]]!=type_stru){
//			cout<<"yes "<<nam<<endl;
			return str[strid].mem_addr[str[strid].mem_id[nam]];
		}
		else{
			return str[strid].mem_addr[str[strid].mem_id[nam]]+judge_remain(str[strid].str_mem_id[str[strid].mem_id[nam]],rem);
		}
	}
	void act(){
		string x;
		cin>>x;
		int i=0;string nam,rem;bool hasdot=false;
		for(i=0;i<=(int)x.length()-1;++i){
			if(x[i]=='.'){
				hasdot=true;
				break;
			}
			nam.push_back(x[i]);
		}
		for(i++;i<=(int)x.length()-1;++i){
			rem.push_back(x[i]);
		}
		int res=0;
//		cout<<"judge "<<nam<<" "<<rem<<endl;
		if(hasdot){
//			cth<<"JUDGE ADDRESS "<<x<<endl;
//			cout<<" ------"<<id[nam]<<" "<<str_reflect_id[id[nam]]<<endl;
			cout<<(res=address[id[nam]]+judge_remain(str_reflect_id[id[nam]],rem))<<endl;
//			cth<<"JUDGE END: "<<res<<endl;
		}
		else{
//			cth<<"JUDGE ADDRESS "<<x<<endl;
			cout<<(res=address[id[nam]])<<endl;
//			cth<<"JUDGE END: "<<res<<endl;
		}
	}
}
namespace operation4{
	string judge_remain(int strid,int remain){
//		cth<<"JUDGE REMAIN-----"<<strid<<" "<<remain<<endl;
//		if(str[strid].cnt==-1) return "";
		int _id=0;
		str[strid].mem_addr.push_back(1e18);
		for(_id=0;_id<=str[strid].cnt;++_id){
			if(remain>=str[strid].mem_addr[_id] and remain<str[strid].mem_addr[_id+1]) break;
		}
//		cth<<"[[[[[find "<<_id<<" "<<str[strid].mem_addr[_id]<<" "<<str[strid].mem_addr[_id]+str[strid].mem_size[_id]-1<<endl;
//		cth<<"judge remain ::::: "<<strid<<" "<<remain<<endl;
		if(str[strid].mem_type[_id]!=type_stru){
			if(str[strid].mem_addr[_id]<=remain and str[strid].mem_addr[_id]+str[strid].mem_size[_id]-1>=remain);
			else{
//				cth<<"Error in "<<strid<<" when remain "<<remain<<" : find "<<_id<<" ["<<str[strid].mem_addr[_id]<<","<<str[strid].mem_addr[_id]+str[strid].mem_size[_id]-1<<"]"<<endl;
				return "";
			}
//			if(remain%str[strid].maxsize!=0) return "";
			return str[strid].mem_name[_id];
		}
		else{
			string t=judge_remain(str[strid].str_mem_id[_id],remain-str[strid].mem_addr[_id]);
			if(t.empty()) return "";
			return (str[strid].mem_name[_id]+"."+t);
		}
		str[strid].mem_addr.pop_back();
	}
	void act(){
		int addr;
		cin>>addr;
//		cth<<"JUDGE-------- "<<addr<<endl;
		if(address.empty()){
			cout<<"ERR"<<endl;
			return;
		}
		address.push_back(1e18);
		int _id=0;
		for(_id=0;_id<=cnt;++_id){
			if(address[_id]<=addr and address[_id+1]>addr) break;
		}
//		cout<<"id-----"<<_id<<endl;
		if(isstr[_id]==false){
			if(addr<address[_id] or addr>address[_id]+sizeall[_id]-1){
				cout<<"ERR"<<endl;
			}
			else{
				cout<<name[_id]<<endl;
			}
		}
		else{
//			cth<<"into[ "<<address[_id]<<" "<<str[str_reflect_id[_id]].totsize<<endl;
			string t=judge_remain(str_reflect_id[_id],addr-address[_id]);
			if(t.empty()) cout<<"ERR"<<endl;
			else cout<<(name[_id]+"."+t)<<endl;
		}
		address.pop_back();
	}
}
/*
0 1
*/
int ops;
signed main(){
//	cth.open("CON");
//	#ifdef ONLINE_JUDGE
//	freopen("struct.in","r",stdin);
//	freopen("struct.out","w",stdout);
//	#else
//	freopen("y3.in","r",stdin);
//	freopen("out.out","w",stdout);
//	#endif
	cin>>ops;
	int op;
	while(ops--){
		cin>>op;
		if(op==1){
//			cout<<"st act 1"<<endl;
			operation1::act();
//			cout<<"ed act 1"<<endl;
		}
		if(op==2){
//			cout<<"st act 2"<<endl;
			operation2::act();
//			cout<<"ed act 2"<<endl;
		}
		if(op==3){
//			cout<<"st act 3"<<endl;
			operation3::act();
//			cout<<"ed act 3"<<endl;
		}
		if(op==4){
//			cout<<"st act 4"<<endl;
			operation4::act();
//			cout<<"ed act 4"<<endl;
		}
	}
}
T4
看到给了答案范围以及答案具有单调性,基本就是二分答案了
然而这道题二分答案不是太好写,有两个需要解决的. 显然我们应该有一个函数来求 “点 \(i\) 至少需要在第 \(d_{i}\) 天放下去,否则就到达不了预定高度” 中的 \(d_{i}\),考虑到 \(n\) 不是很卡,因此直接二分答案,写个二分套二分,但是显然里面还需要一个函数来求 “对给定的 \(a,b\) 和区间 \([l,r]\) 的树的高度”,这里需要我们推个简单式子
显然,当 \(c_{i}\gt 0\) 的时候,由于 \(b_{i}\ge 1\),所以直接求即可
否则,我们应该找出令 \(c_{i}x+b_{i}=0\) 的 \(x\),对左右两边求分段函数
这里需要注意的是,因为这里的 \(x\) 应该是整数,但是对该方程的计算结果不一定是整数,所以要处理一下取整问题
然后就可以 check 了,考虑怎么 check,一个容易想到的贪心思路是我们应该对节点的 \(d_{i}\) 从小到大排序,考虑到最小的 \(d_{i}\) 一定要优先求,因此每次都从当前 \(d_{i}\) 最小的 \(i\) 搜到根节点,沿途未种树的节点加起来和时间戳比对即可
被卡常的一个大幅度优化
设点 \(i\) 至少需要在第 \(d_{i}\) 天放下去,如果需要的优化幅度不是非常大(\(300ms\) 以内),那么直接判断是否存在 \(d_{i}=1 \operatorname{and} i\neq 1\) 即可
否则,维护每个节点的深度,那么当存在 \(d_{i}\lt deep_{i}\) 的时候就可以返回了
注意开 int128
#include<bits/stdc++.h>
using namespace std;
#define int long long
#define endl '\n'
template<typename T>
void read(T& x){
	x=0;bool sym=0;char c=getchar();
    while(!isdigit(c)){sym^=(c=='-');c=getchar();}
    while(isdigit(c)){x=x*10+c-48;c=getchar();}
    if(sym)x=-x;
}
template<typename T,typename... Args>
void read(T& x,Args&... args){
    read(x);read(args...);
}
int n;
struct area{
	int a,b,c;
	__int128 tot_days;
}a[100001];
inline __int128 calc(__int128 a,__int128 b,__int128 c,__int128 l,__int128 r){
	if(c>=0) return (r-l+1)*b+(r-l+1)*(l+r)/2*c;
	__int128 x=(1-b)/c;
	if(c<0) x=min(x,r);
	if(x<l) return r-l+1;
	if(x>r) return (r-l+1)*b+(r-l+1)*(l+r)/2*c;
	return (x-l+1)*b+(x-l+1)*(l+x)/2*c+r-x;
}
inline int cal_days(__int128 a,__int128 b,__int128 c,__int128 mid){
	//firstly cal the min x make the b+cx>=1
	//that if c>0 that cx>=1-b x>=(1-b)/c
	//     if c<0 that cx>=1-b x<=(1-b)/c
//	if(c==0){
		//always the same
//		return mid-ceil(a*1.0/max(1ll,b));
//	}
	if(calc(a,b,c,1,mid)<a) return false;
	int l=0,r=n,res=-2;
	while(l<=r){
		int _mid=(l+r)/2;
		if(calc(a,b,c,_mid,mid)>=a){
			l=_mid+1;
			res=_mid;
		}
		else{
			r=_mid-1;
		}
	}
	return res;
//	if(c>0){
//
//	}
//	if(c<0){
//
//	}
}
vector<int>e[100001];
int fa[100001];
void dfs(int now,int last){
	fa[now]=last;
	for(int i:e[now]){
		if(i!=last){
			dfs(i,now);
		}
	}
}
int p[100001];
bool vis[100001]={true};
int stk[100001];
inline bool judge(){
	memset(vis,0,sizeof vis);vis[0]=true;
	for(int i=1;i<=n;++i){
		p[i]=i;
	}
	sort(p+1,p+n+1,[](int x,int y){return a[x].tot_days<a[y].tot_days;});
	int times=0;
	for(int i=1;i<=n;i++){
		int now=p[i];
		stack<int>st;
		while(vis[now]==false and now!=0){
			st.push(now);
			vis[now]=true;
			now=fa[now];
		}
		if(!st.empty() and st.top()==0) st.pop();
		while(!st.empty()){
			if(a[st.top()].tot_days<++times){
//				cout<<"falsein "<<st.top()<<" "<<a[st.top()].tot_days<<" "<<times<<endl;
				return false;
			}
			st.pop();
		}
 	}
// 	cout<<"acc"<<endl;
 	return true;
}
inline bool check(int mid){
//	cout<<"checkin "<<mid<<endl;
	for(int i=1;i<=n;++i){
		a[i].tot_days=cal_days(a[i].a,a[i].b,a[i].c,mid);
//		a[i].tot_days=mid-a[i].tot_days;
//		cout<<a[i].tot_days<<" ";
		if(a[i].tot_days<0 or (a[i].tot_days==1 and i!=1)){
//			cout<<"falseout "<<endl;
			return false;
		}
	}
//	cout<<endl;
	return judge();
}
/*
4 2 4 2
*/
signed main(){
//	freopen("tree.in","r",stdin);
//	freopen("tree.out","w",stdout);
//	freopen("tree2.in","r",stdin);
//	freopen("out.out","w",stdout);
	read(n);
	for(int i=1;i<=n;++i){
		read(a[i].a,a[i].b,a[i].c);
	}
	for(int i=1;i<=n-1;++i){
		int x,y;
		read(x,y);
		e[x].push_back(y);
		e[y].push_back(x);
	}
	dfs(1,0);
	int l=0,r=1e9,ans=-1;
	while(l<=r){
//		cout<<"check "<<l<<" "<<r<<endl;
		int mid=(l+r)/2;
		if(check(mid)){
			r=mid-1;
			ans=mid;
		}
		else{
			l=mid+1;
		}
	}
	cout<<ans<<endl;
}
CSP-S 2023的更多相关文章
- 【Voyage】GDOI 2023 旅游记 || ECHO.
		\(\color{#FFFFFF}{那是什么样的旅途呢}\) \(\color{#FFFFFF}{真的会害怕很多东西呢.想想害怕的其实不止这样一件事,便产生了"其实都一样没关系的,都应该踏过 ... 
- CSP的今世与未来
		一.从两个工具说起 最近Google又推出了两款有关CSP利用的小工具,其一为CSP Evaluator,这是一个能够评估你当前输入的CSP能否帮助你有效避免XSS攻击的工具,其用法非常简单,在输入框 ... 
- windows2003安装证书服务:csp配置不正确、您没有此密钥容器的写访问权限
		1.填写CA名称后在生成密钥时提示:csp配置不正确或安装不完整. 原因:可能的原因为CS服务(Crysptographic Service)没有启动 . ps:该服务依赖RPC服务,但RP ... 
- CSP -- 运营商内容劫持(广告)的终结者
		缘由 我们公司最近手机端H5 经常受到商户和用户的投诉,说有广告并且导致不能正常进行操作,我们商户自己当然不会加广告了,但是商户和用户可不管这些了,就认为是我们的问题 探索发现根本 目前我们用的很多浏 ... 
- 前端安全配置之Content-Security-Policy(csp)
		什么是CSP CSP全称Content Security Policy ,可以直接翻译为内容安全策略,说白了,就是为了页面内容安全而制定的一系列防护策略. 通过CSP所约束的的规责指定可信的内容来源( ... 
- http://www.oreilly.com/catalog/errataunconfirmed.csp?isbn=9780596529321
		集体智慧勘误表: http://www.oreilly.com/catalog/errataunconfirmed.csp?isbn=9780596529321 ------------------- ... 
- 采用 PAT工具及CSP语言,对一个问题进行自动机 建模
		pat是新加坡国立开发的工具,需要的去官网下http://www.comp.nus.edu.sg/~pat/ ,学了一天,是个不错的自动机验证工具,感觉还不错啊. 验证一个数是否为斐波那契数且为质数 ... 
- Web 安全之内容安全策略 (CSP)
		内容安全策略 (CSP, Content Security Policy) 是一个附加的安全层,用于帮助检测和缓解某些类型的攻击,包括跨站脚本攻击 (XSS) 和数据注入等攻击. 这些攻击可用于实现从 ... 
- 利用CSP探测网站登陆状态
		0x00 背景 今天看到zone里有同学发帖说了探测支付宝登录状态的帖子:http://zone.wooyun.org/content/17665 由此我想到了我们parsec的@/fd 半年前提到的 ... 
- CSP内容安全策略
		在浏览网页的过程中,尤其是移动端的网页,经常看到有很多无关的广告,其实大部分广告都是所在的网络劫持了网站响应的内容,并在其中植入了广告代码.为了防止这种情况发生,我们可以使用CSP来快速的阻止这种广告 ... 
随机推荐
- Less预处理器的使用
			练习页面: <body> <div class="div1"> <div class="div2"></div> ... 
- 计算复杂性学习笔记(TCS笔记)
			感觉最近太摆了,每天很空虚,不愿意搞应试那一套,还是得学点东西.还是准备一边学tcs一边搞搞oi好打icpc,搞这个纯属兴趣,也是填个坑.最近进了一个初中生建的数学交流群,感觉群里初中生也很厉害,开始 ... 
- Django模型中的save方法 精讲
			两种方法定义在Django模型中的save方法有不同的参数处理方式. 第一种方法: def save(self, *args, **kwargs): super().save(*args, **kwa ... 
- 【Java】JNDI实现
			前提情要: 培训的时候都没讲过,也是书上看到过这么个东西,进公司干外包的第二个项目就用了这个鬼东西 自学也不是没尝试过实现,结果各种失败,还找不到问题所在,索性不写了 JNDI实现参考: 目前参考这篇 ... 
- 强化学习中经验池的替代设计——A3C算法
			读论文<Asynchronous methods for deep reinforcement learning>有感 ---------------------------------- ... 
- 【转载】pip install 使用多个.local环境
			原文地址: https://zhuanlan.zhihu.com/p/351468170 ================================ 我们都知道anaconda可以安装不同的py ... 
- vue之父组件与子组件的通信
			1.背景 参数传递(多理解) 1.父传子<c-parent :messagevue="message"></c-parent>,请看下面具体的截图描述 2. ... 
- NVIDIA vGPU vApps/vWS/vCS适配GPU版本介绍
			NVIDIA vGPU 12.0版本-vGPU版本名称变化 - 注: 2021年1月生效 最新名称 NVIDIA Virtual PC (vPC) -曾用名称 NVIDIA GRID Virtual ... 
- dsu on tree 模板
			dsu on tree模板运用 例题以及代码: U41492 树上数颜色 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 记录详情 - 洛谷 | 计算机科学教育新生态 (luogu. ... 
- 【A GUIDE TO CRC ERROR DETECTION ALGORITHM】 (译文2)
			6. A Fully Worked Example 一个完全可行的例子 Having defined CRC arithmetic, we can now frame a CRC calculatio ... 
