2015佛山市选总结

Morning

P1

题目描述:给出一个0、1矩阵,每次选一格,则包括该格在内的左上角区域的数字反转,求将整个矩形变成0的最少次数。

solution
贪心,从右下角往左上角模拟即可。

P2

题目描述:给出一个图,途中的每条边必有一条反向边与其对应,问从0出发走完所有边的费用,不能则输出-1.

solution
题目描述满足欧拉回路,直接把所有边相加即可。只要所有边都属于0的连通块就有解,也就是说图中有孤立点也有解。

P3

题目描述:给出若干个关于N个点的不等式组,且每个点的取值范围为\([0,10000]\),问N号点比1号点至少大多少,数据有矛盾则输出impossible

solution
典型差分约束系统,注意N号点至少比1号点高\(-10000\)分就可以了。

P4

题目描述:在地图上有金矿,银矿和工地,每个工地必须分配一个金矿和一个银矿,且每个矿只能被一个工地分配,问最多有多少个工地可以使用。

solution
典型网络流,注意把工地拆点限制流量。

Afternoon

P1

题目描述:有N堆石子,A和B轮流操作,每次选择一堆石子,可以移去整堆石子或移去的个数与这堆石子的数目互质,问先手是否有必胜策略。

solution
典型博弈论,构造SG函数0,定义num(x)=x的最小质因数是第几个质数
打表可知\(SG[x]=1+num(x),SG[0]=0,SG[1]=1\)
数学归纳法证明:
x为质数时必然满足
归纳假设:对于\(x=kd ,\text d为x的最小质因数\),所有\((x,y)=1,y=pc,c\neq d,\text c为y的最小质因数\),满足\(SG[y]=1+num(y)=1+num(c)\)
则x能到达的y的SG取尽\([1,num(d)]\)的数(其它数不太清楚),而不能取\(num(d)+1\),所以\(SG[x]=1+num(d)\)
证毕。

P2

题目描述:求字符串的第K小子串。

solution
典型后缀数组。

P3

题目描述\(\frac{N(N+1)}{2}\)个人围成一圈,进行N-1轮操作,从编号为1的人开始报数,在第i轮报N-i+1的人出局,第i轮将会有N-i+1个人出局,求最后存活的人的编号。

solution
典型约瑟夫环,外加优化就好了。
\(O(n^2)\)

ans[1]=0;
long long cur=1;
for (int i=2; i<=N; ++i)
{
    long long s=ans[i-1];
    for (int j=1; j<=i; ++j) s=(s+i)%(++cur);
    ans[i]=s;
}

注意到第二个循环每次都是加i,我们可以考虑一次跳多步,跳到需要取模的那一步。可以证明算法是\(O(n)\)的。
\(O(n)\)

ans[1]=0;
long long cur=1;
for (int i=2; i<=N; ++i)
{
    long long s=ans[i-1];
    for (int j=1; j<=i;)
    {
        long long tmp=(cur-s)/(i-1);
        if (s+tmp*i<cur+tmp) ++tmp;
        if (j+tmp-1>i) tmp=i-j+1;
        cur+=tmp;
        s=(s+tmp*i)%cur;
        j+=tmp;
    }
    ans[i]=s;
}

P4

题目描述:两个字符串A和B
1、删除A或B的字符串首字符有该字符对应的代价
2、同时删除A和B的首字符有这两个字符对应的代价
3、删除A的首字符后可对B进行旋转操作
问删完的最小代价

solution
Unknown.

转载于:https://www.cnblogs.com/GerynOhenz/p/4388425.html

Stkcd [股票代码] ShortName [股票简称] Accper [统计截止日期] Typrep [报表类型编码] Indcd [行业代码] Indnme [行业名称] Source [公告来源] F060101B [净利润现金净含量] F060101C [净利润现金净含量TTM] F060201B [营业收入现金含量] F060201C [营业收入现金含量TTM] F060301B [营业收入现金净含量] F060301C [营业收入现金净含量TTM] F060401B [营业利润现金净含量] F060401C [营业利润现金净含量TTM] F060901B [筹资活动债权人现金净流量] F060901C [筹资活动债权人现金净流量TTM] F061001B [筹资活动股东现金净流量] F061001C [筹资活动股东现金净流量TTM] F061201B [折旧摊销] F061201C [折旧摊销TTM] F061301B [公司现金流1] F061302B [公司现金流2] F061301C [公司现金流TTM1] F061302C [公司现金流TTM2] F061401B [股权现金流1] F061402B [股权现金流2] F061401C [股权现金流TTM1] F061402C [股权现金流TTM2] F061501B [公司自由现金流(原有)] F061601B [股权自由现金流(原有)] F061701B [全部现金回收率] F061801B [营运指数] F061901B [资本支出与折旧摊销比] F062001B [现金适合比率] F062101B [现金再投资比率] F062201B [现金满足投资比率] F062301B [股权自由现金流] F062401B [企业自由现金流] Indcd1 [行业代码1] Indnme1 [行业名称1] 季度数据,所有沪深北上市公司的 分别包含excel、dta数据文件格式及其说明,便于不同软件工具对数据的分析应用 数据来源:基于上市公司年报及公告数据整理,或相关证券交易所、各部委、省、市数据 数据范围:基于沪深北证上市公司 A股(主板、中小企业板、创业板、科创板等)数据整理计算
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值