辗转相减见祖宗

高精

#include<bits/stdc++.h>
using namespace std;
#define A 2000
#define P 1
#define N 10
#define ll long long
ll n,T;
char sjdfj[A];
struct bignum
{
ll n[A],l;
bignum(){l=1,memset(n,0,sizeof(n));}
void clear(){while(l>1&&!n[l-1]) l--;}
void print(){
printf("%lld",n[l-1]);
for(ll i=l-2;i>=0;i--){
printf("%0*lld",P,n[i]);
}
printf("\n");
}
void read(){
l=0;
scanf("%s",sjdfj+1);
l=strlen(sjdfj+1);
reverse(sjdfj+1,sjdfj+l+1);
for(ll i=0;i<l;i++){
n[i]=sjdfj[i+1]-'0';
}
}
ll ok(){
//若为0 return1
//若%2==0 return2
//若%2!=0 return3
if(n[0]==0&&l==1) return 1;
// if(n[0]==1&&l==1) return 1;
if(n[0]%2==0) return 2;
if(n[0]%2!=0) return 3;
}
bool operator <(bignum x) const
{
bignum t=*this,tep;
if(t.l!=x.l) return t.l<x.l;
for(ll i=t.l-1;i>=0;i--)
{
if(t.n[i]!=x.n[i]) return t.n[i]<x.n[i];
}
return 0;
}
bool operator >(bignum x) const
{
bignum t=*this;
if(t.l!=x.l) return t.l>x.l;
for(ll i=t.l-1;i>=0;i--)
{
if(t.n[i]!=x.n[i]) return t.n[i]>x.n[i];
}
return 0;
}
bignum operator -(bignum x) const
{
bignum t=*this;
if(t<x) swap(t,x);
ll jie=0;
// t.print();x.print();
for(ll i=0;i<t.l;i++)
{
t.n[i]-=x.n[i];
while(t.n[i]<0)
{
t.n[i]+=N;
jie++;
}
t.n[i+1]-=jie;
jie=0; }
while(!t.n[t.l-1]&&t.l>1) t.l--;
return t;
}
bignum operator *(bignum x) const{
bignum t=*this,tep;
tep.l=t.l+x.l+1;
for(ll i=0;i<t.l;i++)
for(ll j=0;j<x.l;i++){
tep.n[i+j]+=t.n[i]*x.n[j];
}
for(ll i=0;i<tep.l;i++){
if(tep.n[i]>=N)
{
tep.n[i+1]+=tep.n[i]/N;
tep.n[i]%=N;
}
}
tep.clear();
return tep;
}
bignum operator +(bignum x)const{
bignum t=*this;
if(t.l<x.l) t.l=x.l;
t.l++;
for(ll i=0;i<t.l;i++){
t.n[i]+=x.n[i];
if(t.n[i]>=N){
t.n[i+1]+=t.n[i]/N;
t.n[i]%=N;
}
}
t.clear();
return t;
}
bignum operator =(ll x){
l=0;
while(x){
n[l++]=x%N;
x/=N;
}
return *this;
}
bignum operator *(const ll &b){
bignum t=*this,r;
r.l=0;
ll g=0;
for(ll i=0;i<t.l||g;i++){
ll x;
if(i<t.l)
x=t.n[i]*b+g;
else x=g;
r.n[r.l++]=x%N;
g=x/N;
}
return r;
}
bignum operator /(const ll &x){
bignum t=*this,r;
ll tmp=0;
r.l=t.l;
for(ll i=t.l-1;i>=0;i--){
tmp+=t.n[i];
if(tmp>=x){
r.n[i]=tmp/x;
tmp%=x;
}
tmp*=N;
}
r.clear();
return r;
}
}a,b,c;
ll gcd(){
//若为0 return1
//若%2==0 return2
//若%2!=0 return3
while((a.ok()!=1&&b.ok()!=1)){
// printf("a=%lld ",a.ok());
// a.print();
// printf("b=%lld ",b.ok());
// b.print();
ll ok1=a.ok(),ok2=b.ok();
if(ok1==2&&ok2==2){
return 0;
a=a/2,b=b/2;
}
else if(ok1==3&&ok2==3){
if(a<b) swap(a,b);
a=a-b;
}
else if(ok1==2&&ok2==3){
a=a/2;
}
else if(ok1==3&&ok2==2){
b=b/2;
}
}
}
int main()
{/*1 1023 3072*/
// freopen("bf.txt","w",stdout);
scanf("%lld",&T);
for(ll i=1;i<=T;i++){
a.read(),b.read();
// a=a-b;
gcd();
// a.print(),b.print();
if(a.n[0]==0&&b.n[0]==1&&b.l==1&&a.l==1){
printf("Yes\n");
}
else if(a.n[0]==1&&b.n[0]==0&&b.l==1&&a.l==1){
printf("Yes\n");
}
else printf("No\n");
}
}

斯诺

考试代码改了改,数组开小见祖宗

考试时候$re$了

大概就是这样

考试时也维护的前缀和

$60\%$算法

只含$0,1$

我们可以将$0$看作减$1$,$1$看作加一

那么合法方案数就是$sum[r]-sum[l-1]==0$的个数

我们开一个桶存$sum[l]$,那么当前符合就是桶里$sum[i]$个数

查完个数再把$sum[r]$压进桶就行了

注意初始化,当你$sum==0$时也是合法方案,方案数为桶里$sum==0$个数$+1$,你可以先在桶里$0$压一个再进行操作

代码

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define mod 5000000
ll tong[mod+mod+mod+mod],sum[mod+mod][3],sumtp[21111111],sum2[111111111];
ll n,ans=0,all;
char a[mod+mod];
void solve(ll ql,ll qr){
if(ql==qr) return ;
ll mid=(ql+qr)>>1;
solve(ql,mid);solve(mid+1,qr);
ans=rand();
}
ll check(ll l,ll r){
ll len=(r-l+1)/2;
// printf("l=%lld r=%lld len=%lld\n",l,r,len);
// printf("sum0=%lld 1=%lld 2=%lld\n",sum[r][0]-sum[l-1][0],sum[r][1]-sum[l-1][1],sum[r][2]-sum[l-1][2]);
if(sum[r][0]-sum[l-1][0]>len) return 0;
if(sum[r][1]-sum[l-1][1]>len) return 0;
if(sum[r][2]-sum[l-1][2]>len) return 0;
return 1;
}
int main(){
scanf("%lld",&n);
scanf("%s",a+1);
all=1;
for(ll i=1;i<=n;i++){
sum[i][0]=sum[i-1][0];
sum[i][1]=sum[i-1][1];
sum[i][2]=sum[i-1][2];
if(a[i]=='0') sum[i][0]++;
if(a[i]=='1') sum[i][1]++;
if(a[i]=='2') sum[i][2]++,all=0;
}
if(all&&n>1000){
tong[mod]=1;
for(ll i=1;i<=n;i++){
sumtp[i]=sumtp[i-1];
if(a[i]=='0') {
// if(a[i-1]=='1') sumtp[i]=0;
// if(sumtp[i]<0) ans++;
sumtp[i]++;
}
else {
// if(a[i-1]=='0') sumtp[i]=0;
// if(sumtp[i]>0) ans++;
sumtp[i]--;
}
}
for(ll i=1;i<=n;i++){
ans+=tong[mod+sumtp[i]];
tong[mod+sumtp[i]]++;
// printf("sumtp=%lld\n",sumtp[i]); }
printf("%lld\n",ans);
return 0;
}
if(n<=1000)
for(ll i=1;i<=n;i++){
for(ll j=i+1;j<=n;j++){
if(check(i,j)){
ans++;
}
}
}
else solve(1,n);
printf("%lld\n",ans);
}

从$40\%$算法寻找思路

$60\%$算法$2$

维护三个$sum$,当为$0$,$sum[0]-- sum[1]++ sum[2]++$这样就又和上面类似了

然而合法方案数不止$sum[r]-sum[l-1]==0$

合法很难维护找非法的,最后答案就是合法减非法

发现非法$sum$相减肯定$<0$

那么就转化为逆序对问题

树状数组求逆序对

(其实你常数优秀可以$AC$

$100\%$算法

发现前后差异不大,假设你当前答案$1$为QAQ,若这一位仍为$1$,答案就要对应$-$,另外$2$,$0$答案就要$+$

NOIP模拟测试38「金·斯诺·赤」的更多相关文章

  1. NOIP模拟测试19「count·dinner·chess」

    反思: 我考得最炸的一次 怎么说呢?简单的两个题0分,稍难(我还不敢说难,肯定又有人喷我)42分 前10分钟看T1,不会,觉得不可做,完全不可做,把它跳了 最后10分钟看T1,发现一个有点用的性质,仍 ...

  2. NOIP模拟测试30「return·one·magic」

    magic 题解 首先原式指数肯定会爆$long$ $long$ 首先根据欧拉定理我们可以将原式换成$N^{\sum\limits_{i=1}^{i<=N} [gcd(i,N)==1] C_{G ...

  3. NOIP模拟测试9「随·单·题」

    liu_runda出的题,先$\%\%\%\%\%\%\%\%\%\%\%$为敬 随 考试时没有Qj 然后甚至没做,甚至没交 我不知道我怎么想的 这个题挺难改 你需要用到 循环矩阵快速幂,矩阵快速幂优 ...

  4. NOIP模拟测试28「阴阳·虎·山洞」

    写这几个题解我觉得我就像在按照官方题解抄一样 阴阳 题解 将题目中给的阴阳看作黑色和白色 首先我们观察到最后生成图中某种颜色必须是竖着单调递增或竖着单调递减 类似这样 否则不满足这个条件 但合法染色方 ...

  5. NOIP模拟测试20「周·任·飞」

    liu_runda出的题再次$\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%$ 任 题解 题目中为什么反复强调简单路径,没有环 没有环的图中点数-边数=联通块数 前缀和维护边 ...

  6. NOIP模拟测试23「mine·water·gcd」

    mine 题解 一道比较水的dp 考试因为初始化挂掉了只有$80$分 代码有注释 #include<bits/stdc++.h> using namespace std; //无脑dp # ...

  7. NOIP模拟测试16「Drink·blue·weed」

    话说这次考试 Drink 非常棒的一道卡常练习题,适合练习卡常 真的很棒 前置卡常知识 1.char要比int快 char是最快的 输出putchar,输入getchar 在这个题快了7000豪 2. ...

  8. NOIP模拟测试4「礼物·通讯·奇袭」

    礼物. 首先见到期望一定要想dp,看到n的范围无脑想状压, 然后我就只想到这了. dp方程式还是比较好想的,但是我依然想不出来 略经思考   颓题解 依然不会,随便写了个式子 i状态中不含j $f[i ...

  9. [NOIP模拟测试38]题解

    来自达哥的问候…… A.金 显然本题的考察点在于高精而不是裴蜀定理 根据裴蜀定理易得答案为Yes当且仅当$gcd(n,m)=1$,那么考虑怎么在高精度下判互质. 如果$n,m$都能被2整除,那么显然不 ...

随机推荐

  1. 视频格式mkv、mp4、avi、flv、mov、wmv、webm特点和区别

    mkv是一种多媒体封装格式,这个封装格式可把多种不同编码的影像及 16 条或以上不同格式的音频和语言不同的字幕封装到一个 Matroska Media 档内. 它也是其中一种开放原始码的多媒体封装格式 ...

  2. 初识ClickHouse——安装与入门

    前言: 久闻 ClickHouse 大名,一直没有去详细了解.近期看了下 ClickHouse 相关文档,决定安装体验下.想了解 ClickHouse 的小伙伴可以一起跟着学习哦.本篇文章主要介绍 C ...

  3. OO第三单元总结——JML规格

    一.JML简介 1.JML语言的理论基础 JML(Java Modeling Language)是用于对Java程序进行规格化设计的一种表示语言.JML是一种行为接口规格语言 (Behavior In ...

  4. Pytorch实现对卷积的可插拔reparameterization

    需要实现对卷积层的重参数化reparameterization 但是代码里卷积前weight并没有hook,很难在原本的卷积类上用pure oo的方式实现 目前的解决方案是继承原本的卷积,挂载一个we ...

  5. SwiftUI 简明教程之属性包装器

    本文为 Eul 样章,如果您喜欢,请移步 AppStore/Eul 查看更多内容. Eul 是一款 SwiftUI & Combine 教程 App(iOS.macOS),以文章(文字.图片. ...

  6. [刷题] 24 Swap Nodes in Paris

    要求 给定一个链表,对于每两个相邻的节点,交换其位置 示例 1->2->3->4->NULL 2->1->4->3->NULL 实现 1 struct ...

  7. ansible-一键完成LNMP架构_期中架构

    ansible-一键完成LNMP架构 ansible剧本托管地址 https://github.com/Gshelldong/ansible.git 网站架构图 ansible一键完成lnmp架构 a ...

  8. Linux服务之nginx服务篇二(搭建)

    一.简易搭建安装步骤 0.检查环境 1.配置yum源 使用yum list nginx 检查yum源中是否有nginx安装包 #官方网络源需要安装epel-* #或使用251的adv源(老师的yum源 ...

  9. 7.7-9 chage、chpasswd、su

    7.7 chage:修改用户密码有效期 chage命令用于查看或修改用户密码的有效期,有些参数和passwd的功能相同.   -d    设置上一次密码更改的日期 -E    账号过期的日期.日期格式 ...

  10. 揭秘有状态服务上 Kubernetes 的核心技术

    背景 随着 Kubernetes 成为云原生的最热门的解决方案,越来越多的传统服务从虚拟机.物理机迁移到 Kubernetes,各云厂商如腾讯自研上云也主推业务通过Kubernetes来部署服务,享受 ...