首页 > 其他分享 >CSP-S 2020

CSP-S 2020

时间:2023-06-07 21:11:09浏览次数:46  
标签:ch read long int while 2020 400 CSP

日期计算以\(400\)年为周期,每\(400\)年都有恰好\(146097\)天。(\(146097=365 \times 400 +100-4+1\))

预处理出\(400\)年内的情况,将年份模\(400\)即可快速得到答案。

几个简化代码的技巧:

对于格里高利历,以\(1200\)年\(1\)月\(1\)日为起始日,\(r\) 减去跳过的天数(\(2159351\))。(\(2159351=1478\times1461+3-10\))

(为什么要 \(+3\) 呢?因为从 \(1200\) 年后算法与儒略历不同,少算了闰年多的3天,再减去\(1582\)年\(10\)月少的 \(10\) 天,选择 \(1200\) 是因为刚好 \(400\)的倍数,且与 \(1582\)离得近)。

判断历法:\(r\leqslant 2299160\)即为儒略历 。

(\(2299160=1573\times1461+731+31+28+31+30+31+30+31+31+30+3\))

公元前xxx年视为 \(1−x\) 年。

记得开 long long

#include<bits/stdc++.h>
#define N 146097 //格里高利历400年的天数
#define int long 
using namespace std;
int read(){
	int x=0,f=1;char ch=getchar();
	while(ch<'0'||ch>'9'){if(ch=='-')f=-f;ch=getchar();}
	while(ch>='0'&&ch<='9'){x=(x<<1)+(x<<3)+(ch^48);ch=getchar();}
	return x*f;
}
int Q,n,year,month,day;
int d[N],m[N],y[N];
int md(int y,int m){ //格里高利历y年m月的天数
	if(m==2) return y%4?28:(y%100?29:(y%400?28:29));
	return (m==4||m==6||m==9||m==11)?30:31;
}
void pre(){ 
	m[0]=d[0]=1;
	for(int i=1;i<N;++i){
		d[i]=d[i-1]+1,m[i]=m[i-1];y[i]=y[i-1];
		if(d[i]>md(y[i],m[i])) ++m[i],d[i];
		if(m[i]>12) m[i]=1,++y[i];
	}
}//y[i],m[i],d[i]分别表示从0年1月1日经过i天的年月日
signed main(){
	pre();
	Q=read();
	while(Q--){
		n=read();
		if(n>){ //格里高利历
			
		}else{
			year=n/1461*4-4712; //1461是儒略历4年的天数
			n%=1461;
		}
		if(year+y[n]) printf("%d %d %lld\n",d[n],m[n],year+y[n]);
		else printf("%d %d %lld BC\n",d[n],m[n],1-year-y[n]);
	}
	return 0;
} 

P7076 [CSP-S2020] 动物园 :

考虑每一位,要么这一位被动物覆盖,要么这位不被动物覆盖,且这一位不需要饲料
。设符合的位的个数为 \(cnt\),答案为 \(2^{cnt}-n\)。这道题卡 \(unsigned \ long\ long\) 可以开 __int128,也可以特判过 \(cnt\) 为 \(64\) 的情况。

if(k-cnt==64){
    if(n) cout<<ull(-n)<<endl;
	else cout<<"18446744073709551616"<<endl; 
}

当然你不需要背下 \(18446744073709551616\) 来,只要先输出一个(unsigned long long)-1 再加上 \(1\) 就行了。

\(O(kn)\)

#include<bits/stdc++.h>
#define N 1000005
#define int __int128
using namespace std;
int read(){
	int x=0,f=1;char ch=getchar();
	while(ch<'0'||ch>'9'){if(ch=='-')f=-f;ch=getchar();}
	while(ch>='0'&&ch<='9'){x=(x<<1)+(x<<3)+(ch^48);ch=getchar();}
	return x*f;
}
int n,m,c,k,cnt;
int a[N],p[N],q[N];
int b[N],flag[N];
void write(int x){
	if(x>9) write(x/10);
	putchar(x%10+'0');
}
signed main(){
	n=read(),m=read(),c=read(),cnt=k=read();
	for(int i=1;i<=n;++i) a[i]=read();
	for(int i=1;i<=m;++i) p[i]=read(),q[i]=read(),b[p[i]]++;
	for(int i=1;i<=n;++i){
		int x=a[i];
		int pos=0;
		while(x){
			if(x&1) flag[pos]=1;
			x>>=1,pos++;
		}
	}
	for(int i=0;i<=k;++i) if(!flag[i]&&b[i]) cnt--;
	int ans=1;
	for(int i=1;i<=cnt;++i) ans*=2;
  	write(ans-n);
	return 0;
} 

\(O(n)\)

先开一个数组 \(buc_j\) 表示是否有 \(a_i\) 的第 \(j\) 位上是 \(1\)。

又看到题目中保证 \(q_i\) 互不相同,所以一旦出现 \(p_i,q_i\) 满足 \(buc_{p_i}=0\),那么这一位就不能选,因为当前买的饲料中必定没有 \(q_i\)。

不妨设剩下来 \(bit\) 位,那么这 \(bit\) 位既可以是 \(0\) 也可以是 \(1\),共有 \(2^{bit}\) 种动物,减去现有的 \(n\) 种动物即可。

注意要特判 \(bit=64,n=0\) 的情况。读入量较大,建议写快读。

此外 \(buc\) 数组可以用 unsigned long long 变量代替,这样就做到了时间 \(O(n+m)\),空间 \(O(1)\)。

非自己代码:

#include <bits/stdc++.h>
using namespace std;

#define ull unsigned long long
#define gc getchar()

inline ull rd(){
	ull x=0; char s=gc;
	while(!isdigit(s))s=gc;
	while(isdigit(s))x=(x<<1)+(x<<3)+s-'0',s=gc;
	return x;
} ull n,m,c,k,ans,lim,hv;

int main(){
	n=rd(),m=rd(),c=rd(),k=rd();
	for(int i=1;i<=n;i++)hv|=rd(); // 统计每个位是否有 1
	for(int i=1;i<=m;i++)lim|=1ull<<rd(),rd(); // 统计有限制的位
	for(int i=0;i<k;i++)ans+=!((lim>>i)&1)||((hv>>i)&1); // 如果当前位有 1, 或者没有限制,那么都可以选
	if(ans==64&&!n)puts("18446744073709551616");
	else cout<<(ans==64?-n:(1ull<<ans)-n)<<endl;
	return 0;
}

P7077 [CSP-S2020] 函数调用 :

P7078 [CSP-S2020] 贪吃蛇 :

标签:ch,read,long,int,while,2020,400,CSP
From: https://www.cnblogs.com/jiangchen4122/p/17464586.html

相关文章

  • [BUUOJ]bjdctf_2020_babyrop
    bjdctf_2020_babyrop先checksec,64位小端序,MX保护开,其它全关,接着进入IDA分析main函数内很简单,进一步分析后找到关键函数vuln本题没有找到backdoor,所以应该是做基地址泄露然后getshell,整个程序内只有puts函数可以输出内容,因此对puts函数进行修改,先溢出后转到此处,考虑到系统会对堆栈进......
  • HTTP Content-Security-Policy CSP策略
       CSP(ContentSecurityPolicy)内容安全策略是一个额外的安全层,用于检测并削弱某些特定类型的攻击,包括跨站脚本(XSS)和数据注入攻击等。无论是数据盗取,网站内容污染还是恶意软件分发,这些攻击都是主要的手段。   CSP被设计完全向后兼容,不支持CSP的浏览器也能与实现了......
  • 气相色谱质谱联用仪GCMS-QP2020性能和设计特点
    气相色谱质谱联用仪GCMS-QP2020的特点:集成高灵敏度和低实验成本:依托质谱技术,兼容多种载气类型(He,H2,N2),开拓质谱技术分析极限。无需更换离子源,轻松切换离子化方式。1)高灵敏度采用屏蔽板(Shield)技术的整体惰性化高灵敏度离子源和的“偏转透镜(ODlens)技术”配合“新型低噪音CPU板”,有效降......
  • [ACTF2020 新生赛]Include 1 做题笔记
     点开tips 打开源代码看看 没发现什么信息,试试构造?file=php://filter/read=convert.base64-encode/resource=flag.php 得到base64,试着解码 得到flag......
  • MISC|[MRCTF2020]Unravel!!
    解压得到三个文件其中有一个音频叫Look_at_the_file_ending.wav,暗示看文件尾部,使用010editor打开发现key,应该是压缩包的解压密码,但是直接试失败key=U2FsdGVkX1/nSQN+hoHL8OwV9iJB/mSdKk5dmusulz4=查看JM.png文件发现尾部有压缩包使用foremost分离得到图片,图片名称为aes......
  • IDEA 2020.1官网汉化插件安装
    idea终于更新了2020.1版本(推荐使用2020的版本),新增了好多的特性,官方也终于支持了中文语言包,但是有些兄弟下载后在插件市场无法找到官方的汉化包等问题,请安装下面操作即可:1、去IDEA插件中心(https://plugins.jetbrains.com/idea)搜索Chinese(Simplified)LanguagePackEAP2、点进......
  • JOISC 2020 题解
    JOISC2020Day1建筑装饰4Building4我们发现\(A\)的个数是连续的,所以我们只需要DP出最大的\(A\)的个数和最大的\(B\)的个数,若两者都\(\gen\)那么就有解。然后再从后往前推出方案即可。https://qoj.ac/submission/109314*JOISC2020Day1汉堡肉HamburgSteak我们......
  • CSP-J 2020 普及组讲解
    CSP-J2020T1优秀的拆分题目的本质是求\(n\)的二进制表示。求\(n\)的二进制表示,或者每次暴力分解出小于等于\(n\)的最大的\(2\)的正整数次幂。时间复杂度\(O(\log{n})\)。T2直播获奖给定\(n\)个人的分数,对于每个\(i\),请你求出前\(i\)个人的第\(k=\max(1,......
  • [2020集训队论文] 最小连通块
    这是一道交互题。交互库里有一棵$n$个点的树,你可以通过做若干次如下询问来确定这棵树:给定一个节点集合$S$和节点$x$,交互库会告诉你$x$是否在包含$S$的最小连通块中。Details具体的,你需要引用头文件D.h并且实现以下函数:std::vector<std::pair<int,int>>work(int......
  • CSP 202206-3 角色授权
    链接大模拟,用了map,但是TLE了;好在有部分分,能得80.代码如下#include<bits/stdc++.h>usingnamespacestd;intconstN=5005,M=505;intn,m,q,ID[M]; //ID[关联编号]=角色编号stringcurname,curop,curkd,curnm;//当前操作的用户,操作,资源种类,资源名称map<st......