【NOIP模拟题】[状压dp][线段树]

T1

给出一个长度不超过100只包含’B’和’R’的字符串,将其无限重复下去。
比如,BBRB则会形成BBRBBBRBBBRB。现在给出一个区间[l,r]询问该区间内有多少个字符’B’(区间下标从1开始)

思路:
写起走就行了…考试的时候脑抽写了高精度…结果wa完了TAT
主要就是把left、right扩展开到端点,处理小小注意一下就行qwq

#include<iostream>
#include<cstdio>
#include<cstring>
#define LL long long
using namespace std;
int n,tot;
LL le,ri,ans;
char mo[105],c;
void worrk()
{
    cin>>le>>ri;
    int y1=le%n,y2=ri%n,gg=0;
    if(!y1)y1=n;
    if(!y2)y2=n;
    le-=y1;
    ri+=n-y2;
    for(int i=1;i<=n;i++)
    if(mo[i]=='B')tot++;
    for(int i=1;i<y1;i++)
    if(mo[i]=='B')gg++;
    for(int i=n;i>y2;i--)
    if(mo[i]=='B')gg++;
    ans=(ri-le)/(LL)n*(LL)tot;
    ans-=(LL)gg;
    cout<<ans;
}
int main()
{
    freopen("a.in","r",stdin);
    freopen("a.out","w",stdout);
    scanf("%s",mo+1);n=strlen(mo+1);
    worrk();
}

T2

我们要从n种食物选m个出来,安排一个顺序吃掉它(们),每种食物有个美味值ai,然后我们有k个规则,每个规则有 xi, yi 和 ci三个数,如果吃完第xi种食物接下来马上吃第yi种食物,第j种食物的美味值会增加ci。每种食物至多吃一个,求美味值最大的和是多少?
【数据范围】
30% m<=n<=5 ,0<=ci,ai<=1e5
100% m<=n<=18,0<=ci,ai<=1e9

思路:
事实证明这道题貌似以前见到过…
看数据范围就可以看出来…咦,n只有18所以毫无疑问考虑状态压缩….嗯压缩的时候没有用for而是用了队列,结果…后头全T了qwq

#include<iostream>
#include<cstdio>
#include<queue>
#include<map>
#define LL long long
using namespace std;
const int N=20;
int n,m,k,x,y,z;
LL c[N],ans,f[N][N],s[19][(1<<18)+1];
struct node{
    LL zt,ta;
    int las,ch;
};
queue<node>q;
LL max(LL a,LL b)
{
    if(a>b)return a;
    else return b;
}
void worrk()
{
    /*for(int i=1;i<=n;i++)
    {
        node a;
        a.zt=0|1<<(i-1);a.ta=c[i];
        a.las=i;a.ch=1;
        q.push(a);
    }
    while(!q.empty())
    {
        node w=q.front();q.pop();
        if(w.ch==m){
            ans=max(ans,w.ta);
            continue;
        }
        int u=w.las;LL r=w.zt;
        if(s[u][r]<w.ta)s[u][r]=w.ta;
        else continue;
        for(int i=1;i<=n;i++)
        if(i!=u&&!(r&1<<(i-1)))
        {
            node k;
            k.zt=r|1<<(i-1);
            k.ta=f[u][i]+w.ta+c[i];
            k.las=i;k.ch=w.ch+1;
            q.push(k);
        }
    }*/
    for(int i=1;i<(1<<n);i++)
    {
        int tot=0;
        for(int j=0;j<n;j++)
            if(i&1<<j)tot++;
        if(tot>m)continue;
        for(int j=1;j<=n;j++) //this
        {
            if((i&1<<(j-1))==0)continue;
            if(tot==1){
                s[0][i]=s[j][i]=c[j];
                break;
            }
            LL ma=0;
            for(int k=1;k<=n;k++) //last
            {
                if((1<<(k-1)&i)==0||j==k)continue;
                ma=max(ma,s[k][i&(~(1<<(j-1)))]+f[k][j]+c[j]);
            }
            s[j][i]=ma;
            if(tot==m)ans=max(s[j][i],ans);
        }
    }
    cout<<ans<<endl;
}
int main()
{
    freopen("b.in","r",stdin);
    freopen("b.out","w",stdout);
    scanf("%d%d%d",&n,&m,&k);
    for(int i=1;i<=n;i++)
    scanf("%d",&c[i]);
    for(int i=1;i<=k;i++)
    {
        scanf("%d%d%d",&x,&y,&z);
        f[x][y]=max(f[x][y],z);
    }
    worrk();
}

ps:注释的部分是之前用map写的队列(以为1<<18开不下,脑抽orz)


T3

给定一棵树,1,为根节点,有m个操作或询问,操作(x,k)为将x节点权值加k,它儿子加k+1,孙子加k+2,以此类推,查询为求x及它形成子树权值总和。
n<=5e4,m<=1e5

思路:
这道题…拿到后看数据范围,可以判断每次询问或修改要控制在logn左右才行,再加上昨天看了树链剖分,就比较容易会想到是将树铺成一条链,再用线段树维护。由于把公式写复杂了所以考虑复杂了于是乎考试时没写完qwq交了个暴力结果wa了TAT
单点公式:dp[v]-dp[root]+k; dp指深度,root是操作时的根。
知道单点修改之后,注意每次修改的 k-dp[root]是一样的,所以将它延迟在线段树上处理,只需*区间的size即可,而dp[v]在建树时可以区段求和,于是便很好处理了。
代码代码qwq:

#include<iostream>
#include<cstdio>
#include<queue>
#include<vector>
#define R(x) (x<<1|1)
#define L(x) (x<<1)
#define LL long long
using namespace std;
const int N=50005;
int n,q,x,y,head[N],next[N],tov[N],tot,fa[N];
int w[N],id,tail[N];
LL ans;
char c;
struct node{
    int siz,dp,add;
    LL cl;
}tr[N];
struct node2{
    int le,ri,ci;
    LL qq,sum,dps;
}cc[N*4];
void build(int a,int b)
{tot++;next[tot]=head[a];tov[tot]=b;head[a]=tot;}
void dfs(int k)
{
    int u=head[k],v=tov[u];
    tr[k].siz=1;
    while(u)
    {
        tr[v].dp=tr[k].dp+1;
        dfs(v);
        tr[k].siz+=tr[v].siz;
        u=next[u];v=tov[u];
    }
}
void dfs2(int k,int t)
{
    w[k]=++id;fa[id]=k;
    int u=head[k],v=tov[u];
    while(u)
    {
        dfs2(v,v);
        u=next[u];v=tov[u];
    }
    tail[k]=id;
}
void pushup(int u)
{
    cc[u].dps=cc[R(u)].dps+cc[L(u)].dps;
}
void pushdown(int u)
{
    cc[u].sum+=cc[u].dps*(LL)cc[u].ci+cc[u].qq*(LL)(cc[u].ri-cc[u].le+1);
    cc[R(u)].ci+=cc[u].ci;cc[R(u)].qq+=cc[u].qq;
    cc[L(u)].ci+=cc[u].ci;cc[L(u)].qq+=cc[u].qq;
    cc[u].ci=0;cc[u].qq=0;
}
void update(int u)
{
    pushdown(R(u));pushdown(L(u));  //!!!!!!
    cc[u].sum=cc[R(u)].sum+cc[L(u)].sum;
}
void buildtr(int u,int l,int r)
{
    cc[u].le=l;cc[u].ri=r;
    if(l==r)
    {
        cc[u].dps=tr[fa[r]].dp;
        return;
    }
    int mid=(l+r)>>1;
    buildtr(R(u),mid+1,r);
    buildtr(L(u),l,mid);
    pushup(u);
}
void add(int u,int l,int r,int k,int gen)
{
    if(cc[u].le==l&&cc[u].ri==r)
    {
        cc[u].qq+=(k-tr[gen].dp);
        cc[u].ci++;
        pushdown(u);
        return ;
    }
    int mid=(cc[u].le+cc[u].ri)>>1;
    if(mid>=r)add(L(u),l,r,k,gen);
    else if(mid<l)add(R(u),l,r,k,gen);
    else{
        add(L(u),l,mid,k,gen);
        add(R(u),mid+1,r,k,gen);
    }
    update(u);
}
void sear(int u,int l,int r)  //单点dp[v]-dp[gen]+k;->区段处理后延迟更新 
{
    if(cc[u].le==l&&cc[u].ri==r)
    {
        pushdown(u);
        ans+=cc[u].sum;
        return;
    }
    if(cc[u].ci)pushdown(u);
    int mid=(cc[u].le+cc[u].ri)>>1;
    if(mid>=r)sear(L(u),l,r);
    else if(mid<l)sear(R(u),l,r);
    else{
        sear(L(u),l,mid);
        sear(R(u),mid+1,r);
    }
    update(u);
}
void pre()
{
    for(int i=2;i<=n;i++)
    {
        scanf("%d",&x);
        build(x,i);
    }
    tr[1].dp=1;dfs(1);
    dfs2(1,1);
    buildtr(1,1,n);
}
void worrk()
{
    for(int i=1;i<=q;i++)
    {
        c=getchar();while(c!='A'&&c!='Q')c=getchar();
        if(c=='A')
        {
            scanf("%d%d",&x,&y);
            add(1,w[x],tail[x],y,x);
        }
        else{
            scanf("%d",&x);
            ans=0;sear(1,w[x],tail[x]);
            printf("%I64d\n",ans);
        }
    }
}
int main()
{
    freopen("c.in","r",stdin);
    freopen("c.out","w",stdout);
    scanf("%d%d",&n,&q);
    pre();
    worrk();
}

注意update时先pushdown!!!唉唉唉╮(╯▽╰)╭
无关紧要的话:离noip还有9天,fighting!

标题SpringBoot智能在线预约挂号系统研究AI更换标题第1章引言介绍智能在线预约挂号系统的研究背景、意义、国内外研究现及论文创新点。1.1研究背景与意义阐述智能在线预约挂号系统对提升医疗服务效率的重要性。1.2国内外研究现分析国内外智能在线预约挂号系统的研究与应用情况。1.3研究方法及创新点概述本文采用的技术路线、研究方法及主要创新点。第2章相关理论总结智能在线预约挂号系统相关理论,包括系统架构、开发技术等。2.1系统架构设计理论介绍系统架构设计的基本原则和常用方法。2.2SpringBoot开发框架理论阐述SpringBoot框架的特点、优势及其在系统开发中的应用。2.3数据库设计与管理理论介绍数据库设计原则、数据模型及数据库管理系统。2.4网络安全与数据保护理论讨论网络安全威胁、数据保护技术及其在系统中的应用。第3章SpringBoot智能在线预约挂号系统设计详细介绍系统的设计方案,包括功能模块划分、数据库设计等。3.1系统功能模块设计划分系统功能模块,如用户管理、挂号管理、医生排班等。3.2数据库设计与实现设计数据库表结构,确定字段类型、主键及外键关系。3.3用户界面设计设计用户友好的界面,提升用户体验。3.4系统安全设计阐述系统安全策略,包括用户认证、数据加密等。第4章系统实现与测试介绍系统的实现过程,包括编码、测试及优化等。4.1系统编码实现采用SpringBoot框架进行系统编码实现。4.2系统测试方法介绍系统测试的方法、步骤及测试用例设计。4.3系统性能测试与分析对系统进行性能测试,分析测试结果并提出优化建议。4.4系统优化与改进根据测试结果对系统进行优化和改进,提升系统性能。第5章研究结果呈现系统实现后的效果,包括功能实现、性能提升等。5.1系统功能实现效果展示系统各功能模块的实现效果,如挂号成功界面等。5.2系统性能提升效果对比优化前后的系统性能
在金融行业中,对信用风险的判断是核心环节之一,其结果对机构的信贷政策和风险控制策略有直接影响。本文将围绕如何借助机器学习方法,尤其是Sklearn工具包,建立用于判断信用况的预测系统。文中将涵盖逻辑回归、支持向量机等常见方法,并通过实际操作流程进行说明。 一、机器学习基本概念 机器学习属于人工智能的子领域,其基本理念是通过数据自动学习规律,而非依赖人工设定规则。在信贷分析中,该技术可用于挖掘历史数据中的潜在规律,进而对未来的信用表现进行预测。 二、Sklearn工具包概述 Sklearn(Scikit-learn)是Python语言中广泛使用的机器学习模块,提供多种数据处理和建模功能。它简化了数据清洗、特征提取、模型构建、验证与优化等流程,是数据科学项目中的常用工具。 三、逻辑回归模型 逻辑回归是一种常用于分类任务的线性模型,特别适用于二类问题。在信用评估中,该模型可用于判断借款人是否可能违约。其通过逻辑函数将输出映射为0到1之间的概率值,从而表示违约的可能性。 四、支持向量机模型 支持向量机是一种用于监督学习的算法,适用于数据维度高、样本量小的情况。在信用分析中,该方法能够通过寻找最佳分割面,区分违约与非违约客户。通过选用不同核函数,可应对复杂的非线性关系,提升预测精度。 五、数据预处理步骤 在建模前,需对原始数据进行清理与转换,包括处理缺失值、识别异常点、标准化数值、筛选有效特征等。对于信用评分,常见的输入变量包括收入水平、负债比例、信用历史记录、职业稳定性等。预处理有助于减少噪声干扰,增强模型的适应性。 六、模型构建与验证 借助Sklearn,可以将数据集划分为训练集和测试集,并通过交叉验证调整参数以提升模型性能。常用评估指标包括准确率、召回率、F1值以及AUC-ROC曲线。在处理不平衡数据时,更应关注模型的召回率与特异性。 七、集成学习方法 为提升模型预测能力,可采用集成策略,如结合多个模型的预测结果。这有助于降低单一模型的偏差与方差,增强整体预测的稳定性与准确性。 综上,基于机器学习的信用评估系统可通过Sklearn中的多种算法,结合合理的数据处理与模型优化,实现对借款人信用况的精准判断。在实际应用中,需持续调整模型以适应市场变化,保障预测结果的长期有效性。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值