首页 > 其他分享 >12.27闲话

12.27闲话

时间:2023-12-27 21:12:39浏览次数:37  
标签:return int 闲话 12.27 char while && getchar

我去怎么明天就考试了

今天没啥抽象事,就是分块入门9题我T1都没写过去非常恼

带修莫队没写出来,要是线段树就直接乱杀了,分块估计也能乱杀我非常恼

TLE的带修莫队
#include<bits/stdc++.h>
#define int long long
/* --------------- fast io --------------- */
using namespace std;
namespace Fread{const int SIZE = (1 << 18);char buf[SIZE],*S,*T;inline char getchar() {if(S==T){T = (S = buf) + fread(buf,1,SIZE,stdin); if(S==T) return '\n';} return *S++;}}
namespace Fwrite {const int SIZE = (1 << 18);char buf[SIZE],*S=buf,*T=buf+SIZE;inline void flush(){fwrite(buf,1,S-buf,stdout), S=buf;}inline void putchar(char c){*S++=c;if(S==T)flush();}struct NTR{ ~NTR() { flush(); }}ztr;}
#ifdef ONLINE_JUDGE
#define getchar Fread::getchar
#define putchar Fwrite::putchar
#endif
namespace Fastio{
    struct Reader{
        template <typename T>
        Reader&operator>>(T&x){char c=getchar();bool f=false;while (c<'0'||c>'9') { if(c == '-')f = true;c=getchar();}x=0;while(c>='0'&&c<='9'){x=(x<<1)+(x<<3)+(c^48);c=getchar();}if(f)x=-x;return *this;}
        Reader&operator>>(double & x) {char c=getchar();short f=1,s=0;x=0;double t=0;while((c<'0'||c>'9')&&c!='.'){if(c=='-')f*=-1;c=getchar();}while(c>='0'&&c<='9'&&c!='.')x=x*10+(c^48),c=getchar();if(c=='.')c=getchar();else return x*=f,*this;while(c>='0'&&c<='9')t=t*10+(c^48),s++,c=getchar();while(s--)t/=10.0;x=(x+t)*f;return*this;}
        Reader&operator>>(long double&x){char c=getchar();short f=1,s=0;x=0;long double t=0;while((c<'0'||c>'9')&&c!='.'){if(c=='-')f*=-1;c=getchar();}while(c>='0'&&c<='9'&&c!='.')x=x*10+(c^48),c=getchar();if(c=='.')c=getchar();else return x*=f,*this;while(c>='0'&&c<='9')t=t*10+(c^48),s++,c=getchar();while(s--)t/=10.0;x=(x+t)*f;return*this;}
        Reader&operator>>(__float128&x){char c=getchar();short f=1,s=0;x=0;__float128 t=0;while((c<'0'||c>'9')&&c!='.'){if(c=='-')f*=-1;c=getchar();}while(c>='0'&&c<='9'&&c!='.')x=x*10+(c^48),c=getchar();if(c=='.') c = getchar();else return x*=f, *this;while(c>='0'&&c<='9')t=t*10+(c^48),s++,c=getchar();while(s--)t/=10.0;x=(x+t)*f;return *this;}
        Reader&operator>>(char&c){c=getchar();while(c=='\n'||c==' '||c=='\r')c=getchar();return *this;}
        Reader&operator>>(char*str){int len=0;char c=getchar();while(c=='\n'||c==' '||c=='\r')c=getchar();while(c!='\n'&&c!=' '&&c!='\r')str[len++]=c,c=getchar();str[len]='\0';return *this;}
        Reader&operator>>(string&str){char c=getchar();str.clear();while(c=='\n'||c==' '||c=='\r')c=getchar();while(c!='\n'&&c!=' '&&c!='\r')str.push_back(c),c=getchar();return *this;}
        template<class _Tp>
        Reader&operator>>(vector<_Tp>&vec){for(unsigned i=0;i<vec.size();i++)cin>>vec[i];return *this;}
        template<class _Tp,class _tp>
        Reader&operator>>(pair<_Tp,_tp>&a){cin>>a.first>>a.second;return *this;}
        Reader(){}
    }cin;
    inline int read(){int n;cin>>n;return n;}
    const char endl='\n';
    struct Writer{
    static const int set_precision = 6;
    typedef int mxdouble;
        template<typename T>
        Writer&operator<<(T x){if(x==0)return putchar('0'),*this;if(x<0)putchar('-'),x=-x;static int sta[45];int top=0;while(x)sta[++top]=x%10,x/=10;while(top)putchar(sta[top]+'0'),--top;return*this;}
        Writer&operator<<(double x){if(x<0)putchar('-'),x=-x;mxdouble _=x;x-=(double)_;static int sta[45];int top=0;while(_)sta[++top]=_%10,_/=10;if(!top)putchar('0');while(top)putchar(sta[top]+'0'),--top;putchar('.');for(int i=0;i<set_precision;i++)x*=10;_=x;while(_)sta[++top]=_%10,_/=10;for(int i=0;i<set_precision-top;i++)putchar('0');while(top)putchar(sta[top]+'0'),--top;return*this;}
        Writer&operator<<(long double x){if(x<0)putchar('-'),x=-x;mxdouble _=x;x-=(long double)_;static int sta[45];int top=0;while(_)sta[++top]=_%10,_/=10;if(!top)putchar('0');while(top)putchar(sta[top]+'0'),--top;putchar('.');for(int i=0;i<set_precision;i++)x*=10;_=x;while(_)sta[++top]=_%10,_/=10;for(int i=0;i<set_precision-top;i++)putchar('0');while(top)putchar(sta[top]+'0'),--top;return*this;}
        Writer&operator<<(__float128 x){if(x<0)putchar('-'),x=-x;mxdouble _=x;x-=(__float128)_;static int sta[45];int top=0;while(_)sta[++top]=_%10,_/=10;if(!top)putchar('0');while(top)putchar(sta[top]+'0'),--top;putchar('.');for(int i=0;i<set_precision;i++)x*=10;_=x;while(_)sta[++top]=_%10,_/=10;for(int i=0;i<set_precision-top;i++)putchar('0');while(top)putchar(sta[top]+'0'),--top;return*this;}
        Writer&operator<<(char c){putchar(c);return*this;}
        Writer& operator<<(char*str){int cur=0;while(str[cur])putchar(str[cur++]);return *this;}
        Writer&operator<<(const char*str){int cur=0;while(str[cur])putchar(str[cur++]);return *this;}
        Writer&operator<<(string str){int st=0,ed=str.size();while(st<ed) putchar(str[st++]);return *this;}
        template<class _Tp>
        Writer&operator<<(vector<_Tp>vec){for(unsigned i=0;i<vec.size()-1;i++)cout<<vec[i]<<" ";cout<<vec[vec.size()-1];return *this;}
        template<class _Tp,class _tp>
        Writer&operator<<(pair<_Tp,_tp>a){cout<<a.first<<" "<<a.second;return *this;}Writer(){}
    }cout;
}
#define cin Fastio::cin
#define cout Fastio::cout
#define endl Fastio::endl
#define max(a,b) ((a)>(b)?(a):(b))
#define min(a,b) ((a)<(b)?(a):(b))
#define read Fastio::read
/* --------------- fast io --------------- */
int n,m,k,sqrtn,b[1000001],a[1000001],ans[1000001],K8=0,He=1;
class Mobius{
public:
    int sum,bl[1000001];
    class block{
    public:
        int l,r,id,k,t;
        inline void Join(int li,int ri,int i,int time){
            l=li,r=ri,
            id=i,k=(li-1)/sqrtn+1;
            t=time;
            return;
        }
		inline bool operator<(block p){
			if(k!=p.k)return l<p.l;
			if(k&1)return r<p.r;
			return r>p.r;
		}
    }blo[100001];
    class change{
    public:
        int l,r,val,id;
        inline void Join(int li,int ri,int i,int v){
            l=li,r=ri,id=i,val=v;
        }
    }ch[100001];
    inline void Join(int i){
        int opt=read(),l=read(),r=read(),val=read();
        if(opt==1)blo[++K8].Join(r,r,K8,He);
        else ch[++He].Join(l,r,He,val);
        return;
    }
	inline void Add(int i){
        sum+=b[i];
    }
	inline void Del(int i){
        sum-=b[i];
    }
    inline void Addt(int t,int l,int r){
        for(int i=ch[t].l;i<=ch[t].r;i++)
            b[i]+=ch[t].val;
        // cout<<ch[t].val;
        sum+=ch[t].val*(min(r,ch[t].r)-max(l,ch[t].l)+1);
        // cout<<ch[t].val*(min(r,ch[t].r)-max(l,ch[t].l))<<endl;
        //
    }
    inline void Delt(int t,int l,int r){
		for(int i=ch[t].l;i<=ch[t].r;i++)
            b[i]-=ch[t].val;
        // cout<<ch[t].val;
        sum-=ch[t].val*(min(r,ch[t].r)-max(l,ch[t].l)+1);
        // cout<<ch[t].val*(min(r,ch[t].r)-max(l,ch[t].l))<<endl;
        //
    }
    inline void Solve(){
		sort(blo+1,blo+K8+1);
		int l=1,r=0,t=1;
		for(int i=1;i<=K8;++i){
			// cout<<"case"<<i<<":"<<endl;
            while(l>blo[i].l)
                Add(--l);
            // cout<<"sumADD1="<<sum<<endl;
			while(r<blo[i].r)
                Add(++r);
            // cout<<"sumADD2="<<sum<<endl;
			while(l<blo[i].l)
                Del(l++);
            // cout<<"sumDel1="<<sum<<endl;
			while(r>blo[i].r)
                Del(r--);
            // cout<<"sumDel1="<<sum<<endl;
			while(t<blo[i].t)
                Addt(++t,blo[i].l,blo[i].r);
            // cout<<"sumADDT1="<<sum<<endl;
			while(t>blo[i].t)
                Delt(t--,blo[i].l,blo[i].r);
            // cout<<"sumDELT1="<<sum<<endl;
			ans[blo[i].id]=sum;
            // cout<<"sum="<<sum<<endl<<endl;
		}
	}
}bl;
signed main(){
    freopen("1.in","r",stdin);
    freopen("1.out","w",stdout);
    n=read();
    sqrtn=sqrt(n);
    for(int i=1;i<=n;i++)
        b[i]=a[i]=read();
    for(int i=1;i<=n;++i){
        bl.Join(i);
    }
    bl.Solve();
    for(int i=1;i<=K8;i++){
        cout<<ans[i]<<endl;
    }

}

感觉白给的原因是思路上比较暴力导致的

谁能帮我调调为啥似了数列分块1

然后就是我又去不了1机房了,洛谷再见

后面的到时候补

标签:return,int,闲话,12.27,char,while,&&,getchar
From: https://www.cnblogs.com/LuoTianYi66ccff/p/17931442.html

相关文章

  • 12.27每日总结2
    中午的时候做了软件企业文化的大作业公司管理1公司管理体系概述在我们公司,建立一个完善的公司管理体系是为了确保公司运营高效、有序,实现长期发展目标。公司管理体系包括管理理念、目标、架构和运作机制等方面,为公司的各项管理工作提供指导和支持。  1.1公司管理理念 ......
  • 12.27每日总结
    今天早上进行了软件构造的实验作业实验二:百度图像增强与特效SDK实验一、实验要求任务一:下载配置百度图像增强与特效的Java相关库及环境(占10%)。任务二:了解百度图像增强与特效相关功能并进行总结(占20%)。任务三:完成图像增强GUI相关功能代码并测试调用,要求上传自己的模糊照片进行......
  • 雅礼 2023.12.27 习题课记录
    雅礼2023.12.27习题课记录前言这一场罚时多,都是一些低级错误。好吧全都是水题。水题(只放代码)莫诺卡普参加了一场编程比赛,其中包括\(26\)个问题,从A到Z命名。问题按难度排序。此外,已知莫诺卡普可以在\(1\)分钟内解决问题A,在\(2\)分钟内解决问题B,\(\dots\),在\(2......
  • 百度网盘(百度云)SVIP超级会员共享账号每日更新(2023.12.27)
    一、百度网盘SVIP超级会员共享账号可能很多人不懂这个共享账号是什么意思,小编在这里给大家做一下解答。我们多知道百度网盘很大的用处就是类似U盘,不同的人把文件上传到百度网盘,别人可以直接下载,避免了U盘的物理载体,直接在网上就实现文件传输。百度网盘SVIP会员可以让自己百度账......
  • 金蝶云表单插件开发--物料清单BOM获取老系统的BOM信息【2023.12.27】
    需求:1、新系统中同一产品编码,可以通过快捷获取老系统中的同一产品编码的BOM信息;2、数据信息查询:通过存储过程去查询,再转入子项明细中;     usingSystem;usingSystem.Collections.Generic;usingSystem.Linq;usingSystem.Text;usingSystem.Data;usingSystem.Com......
  • 闲话12.26
    咋今天啥也没干。早上来机房上早读啦......
  • 闲话12.25
    我草今天累死了......
  • 闲话12.24
    在学校的第一天。上午下午卷了昨天讲的《数论》,感觉收获很多啊,抽象的计数题也见了一大堆......
  • 2023-12-24 闲话
    换电脑日记。首先我想换一台笔记本。发现自己机子跑不动模型。于是打算换一个。因为想跑模型,所以需要gpu。捎带脚发现cuda得另外装以及tensorflow比torch拉这个事情。但是我真的很喜欢model.fit()。网上的说法是使用cuda需要独立显卡,看了一眼huaweimate14发现这......
  • 闲话12.23
    回二南了啊。上午逆天数论,讲课人不讲数论,讲了一坨线代。不过看在我都听懂的份上不追究了......