原题大战D1

吐槽:

  1. T1 \(O(N^2)\; N \leq 26\) N大时还要写高精, 可以增加难度

  2. T2 不给范围

  3. T3 居然没有完全卡掉 不对应该赞美出题人

  4. T4 PJ考个四边形不等式?? orz 出题人 %%%

这里是点名被卡的直接高精选手.

并没有感觉很卡啊, 写了就过了啊

因为平常高精求余是这么写的

pair<string, string> divide(string a, string b){
for(int i=0;i<a.size()-b.size();++i)
ans+=divide(a, i, i+b.size(), b) ; // 顺带求出余数
}

但是我的高精是这样的:

string mod(string x, string y){
string ans ;
for(int i=0;i<x.size();++i) {
ans=ans+x[i] ;
while(!cmp(ans,y)) minu(ans, y) ;
}
return ans ;
}

这种写法的优点在于:

  1. 码量小(高精除了除码量都不大)

  2. 常数小, 具体来说, 采用第一种写法执行了10次乘法(高精乘单精)以求出除得的值(但其实用二分只用至多4次, 而且不断加也可以), 而这里执行的是减法, 不需要取余,所以常数较小. 并且该算法较玄学, 卡不满? 并且开上O2, O3后, STL常数极小

  3. 能AC本题

gcd主要代码如下:

string gcd(string x, string y){
if(y == 1) return 1; // 加速
if(y == "0" || y.empty()) return x;
return gcd(y, mod(x, y)) ;
}

可以看见特判了1, 这是因为y=1要执行10*len(x)次高精减法及判断

并且可以发现, 在y变大时, 执行减法次数逐渐缩小, 而很小时取膜可以让较大的数减少一个很大的值(说了这么多就是玄学算法过了2333)

T1

题意

给出一颗二叉树的前序遍历和后序遍历,求有多少种这样的二叉树

解法

考虑递归的求解, 一个节点的子树是他在前序遍历中的位置到他在后序遍历中的位置

那么如果一个节点只有一颗子树, 挂在左边/右边并不会影响遍历, 即方案数乘2

知识点

递归

代码

#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<queue>
using namespace std ;
#define int long long
int power(int a,int b){ int res=1, car=a ; while(b){ if(b&1) res*=car ; car*=car ; b>>=1 ; } return res; }
string p, q; int len ; int cnt;
void calc(int a1,int b1,int a2,int b2){ int i; if(a1>=b1) return; for(i=a2;i<=b2-1;++i) if(p[a1+1] == q[i]) break; if(i==b2-1) ++cnt; calc(a1+1,a1+1+(i-a2),a2,i); calc(a1+1+(i-a2)+1,b1,i+1,b2-1);}
signed main(){ freopen("tree.in", "r", stdin); freopen("tree.out", "w", stdout); cin>>p>>q ; len = p.size() ; calc(0,len-1,0,len-1); printf("%lld\n", power(2, cnt));}

T2

题意

定义一个八连通的联通块的块大小为其权值, 求所有的权值中

  1. 最大的是多少

  2. 大于等于一个给定k的有多少个

解法

无脑暴力BFS即可

O(NM)

错误

在判断能否走向一个方向时, 写错函数名(复制时忘记修改)导致考场爆0

现已修改

知识点

BFS

代码

#pragma optimize(2)
#pragma optimize(3) #include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<queue>
#define pir pair<int, int>
using namespace std ;
int mp[1005][1005]; int n,m,k ; queue< pir > q; int vis[1005][1005] ;
int chk(pir x) {return mp[x.first][x.second]=='.'; }
pir up(pir x){ return make_pair(x.first-1, x.second) ; }
pir dn(pir x){ return make_pair(x.first+1, x.second) ; }
pir le(pir x){ return make_pair(x.first, x.second+1) ; }
pir ri(pir x){ return make_pair(x.first, x.second-1) ; }
pir ul(pir x){ return make_pair(x.first+1, x.second-1) ; }
pir ur(pir x){ return make_pair(x.first+1, x.second+1) ; }
pir dl(pir x){ return make_pair(x.first-1, x.second-1) ; }
pir dr(pir x){ return make_pair(x.first-1, x.second+1) ; }
#define put(X) cout<<"At "<<k.first<<" "<<k.second<<endl
int bfs(int sx, int sy, int num){
q.push(make_pair(sx, sy));
vis[sx][sy]=num; int wyxkk=0 ;
while(!q.empty()){
pir k = q.front(); q.pop(); ++wyxkk ;
//cout<<"At "<<k.first<<" "<<k.second<<endl ;
if((!vis[up(k).first][up(k).second]) && chk(up(k))) vis[up(k).first][up(k).second]=num, q.push(up(k));
if((!vis[dn(k).first][dn(k).second]) && chk(dn(k))) vis[dn(k).first][dn(k).second]=num, q.push(dn(k));
if((!vis[le(k).first][le(k).second]) && chk(le(k))) vis[le(k).first][le(k).second]=num, q.push(le(k));
if((!vis[ri(k).first][ri(k).second]) && chk(ri(k))) vis[ri(k).first][ri(k).second]=num, q.push(ri(k));
if((!vis[ul(k).first][ul(k).second]) && chk(ul(k))) vis[ul(k).first][ul(k).second]=num, q.push(ul(k));
if((!vis[ur(k).first][ur(k).second]) && chk(ur(k))) vis[ur(k).first][ur(k).second]=num, q.push(ur(k));
if((!vis[dl(k).first][dl(k).second]) && chk(dl(k))) vis[dl(k).first][dl(k).second]=num, q.push(dl(k));
if((!vis[dr(k).first][dr(k).second]) && chk(dr(k))) vis[dr(k).first][dr(k).second]=num, q.push(dr(k));
}
return wyxkk ;
}
int ans=-0x3f3f3f3f, pans=0 ;
int main(){
freopen("storm.in", "r" , stdin); freopen("storm.out", "w", stdout);
scanf("%d%d", &n, &m) ;
for(int i=1;i<=n;++i){
string p; cin>>p;
for(int j=1;j<=m;++j) mp[i][j]=p[j-1];
}
scanf("%d", &k);
for(int i=1;i<=n;++i)
for(int j=1;j<=m;++j)
if(!vis[i][j] && chk(make_pair(i, j))) {
int pm = bfs(i, j, 1) ;
//cout<<pm<<endl;
ans=max(ans, pm); if(pm >= k) ++pans ;
}
cout<<pans<<" "<<ans<<endl ;
}

T3

题意

求两个大数的gcd

解法

暴力gcd, 套个高精度即可

知识点

高精度, gcd

代码

#pragma optimize(2)
#pragma optimize(3) #include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<queue>
using namespace std ;
int cmp(string str1,string str2){ if(str1.size()!=str2.size()) return str1.size() < str2.size() ; else for(int i=0; i<str2.size(); ++i) if(str1[i] != str2[i]) return str1[i] < str2[i] ; return 0 ;}
string minu(string str1, string str2){ if(!cmp(str1, str2) && !cmp(str2, str1)) return "" ; int Q = str1.size()-str2.size() ; for(int i=str2.size()-1; i>=0; --i) str1[i+Q]-=(str2[i]-'0') ; for(int i=str1.size()-1; i>0; --i) if(str1[i] < '0') str1[i]+=10, --str1[i-1] ; str1.erase(0,str1.find_first_not_of('0'));return str1 ; }
string mod(string str1,string str2){ string ans ; ans.clear() ; for(int i=0; i<str1.size(); ++i) { ans = ans+str1[i] ; while(!cmp(ans, str2)) ans=minu(ans, str2); } return ans ; }
string gcd(string x, string y){ if(x.empty() || x=="0") return y ; return gcd(mod(y,x), x) ; }
int main(){ freopen("gcd.in", "r" , stdin); freopen("gcd.out", "w", stdout); string p,q; cin>>p>>q; if(p=="1" || q=="1") return puts("1"),0; cout<<gcd(p, q)<<endl; }

T4

题意

石子合并

解法

原题……

众所周知石子合并满足四边形不等式, 打个(我从没打过)的四边形不等式即可

代码奇短?

知识点

四边形不等式, DP

代码

#pragma optimize(2)
#pragma optimize(3) #include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<queue>
using namespace std ;
int a[4005], sum[4005]; int dp[4005][4005], P[4005][4005], ans=0x3f3f3f3f, n;
int main(){
freopen("stone.in", "r", stdin); freopen("stone.out", "w", stdout) ; scanf("%d",&n);
for(int i=1;i<=n;i++){ scanf("%d",&a[i]); a[i+n]=a[i]; sum[i]=sum[i-1]+a[i]; P[i][i]=i; } for(int i=1+n;i<=(n<<1);i++){ sum[i]=sum[i-1]+a[i]; P[i][i]=i; }
for(int i=(n<<1)-1;i;i--)
for(int j=i+1,pos=0,tmp=0x3f3f3f3f;j<=(n<<1);j++,pos=0,tmp=0x3f3f3f3f)
for(int k=P[i][j-1];k<=P[i+1][j];k++) if(dp[i][k]+dp[k+1][j]+(sum[j]-sum[i-1])<tmp) tmp=dp[i][k]+dp[k+1][j]+(sum[j]-sum[i-1]), pos=k, P[i][j]=pos, dp[i][j]=tmp;
for(int i=1;i<=n;i++) ans=min(ans,dp[i][i+n-1]); printf("%d\n",ans);
}

JZOJPJ-C 8/21题解的更多相关文章

  1. CF Global Round 21 题解 (CDEG)

    C 把 \(a,b\) 全拆开然后比较即可(因为分裂和合并是互逆的) 注意开 long long . using namespace std; typedef long long ll; typede ...

  2. LeetCode(21)题解:Merge Two Sorted Lists

    https://leetcode.com/problems/merge-two-sorted-lists/ Merge two sorted linked lists and return it as ...

  3. 模拟21 题解(waiting)

    留坑待填 效率!!! 题还没改Oh,NO!!!

  4. ●UOJ 21 缩进优化

    题链: http://uoj.ac/problem/21 题解: ...技巧题吧 先看看题目让求什么: 令$F(x)=\sum_{i=1}^{n}(\lfloor a[i]/x \rfloor +a[ ...

  5. 【洛谷2015】【CJOJ1976】二叉苹果树

    题面 Description 有一棵苹果树,如果树枝有分叉,一定是分2叉(就是说没有只有1个儿子的结点)这棵树共有N个结点(叶子点或者树枝分叉点),编号为1-N,树根编号一定是1.我们用一根树枝两端连 ...

  6. 【UOJ348】【WC2018】州区划分 状压DP FWT

    题目大意 给定一个\(n\)个点的无向图,对于每种 \(n\) 个点的划分\(\{S_1,S_2,\ldots,S_k\}\),定义它是合法的,当且仅当每个点都在其中的一个集合中且对于任何的\(i\i ...

  7. 【刷题】LOJ 6226 「网络流 24 题」骑士共存问题

    题目描述 在一个 \(\text{n} \times \text{n}\) 个方格的国际象棋棋盘上,马(骑士)可以攻击的棋盘方格如图所示.棋盘上某些方格设置了障碍,骑士不得进入. 对于给定的 \(\t ...

  8. 【BZOJ3872】Ant colony(二分,动态规划)

    [BZOJ3872]Ant colony(二分,动态规划) 题面 又是权限题... Description There is an entrance to the ant hill in every ...

  9. 【bzoj4709】[Jsoi2011]柠檬 斜率优化

    题目描述 给你一个长度为 $n$ 的序列,将其分成若干段,每段选择一个数,获得 $这个数\times 它在这段出现次数的平方$ 的价值.求最大总价值. $n\le 10^5$ . 输入 第 1 行:一 ...

随机推荐

  1. Ubuntu下安装 Mysql

    MYSQL在ubuntu16.04下的编译安装mysql-5.6.23.tar.gz 为减少安装过程中因权限带来个各种问题,建议全程用root用户编译安装,步骤如下: 1.安装依赖文件  apt-ge ...

  2. Java虚拟机05.2(内存分配)

    jdk1.7中堆内存分为:年轻代+老年代+永久代.但是永久代有作为非堆内存存在,也就是说堆内存的大小应该为年轻代+老年代.在tomcat容器中,如果jsp页面过多可能出现永久代溢出.通常栈溢出都是程序 ...

  3. shiro#springboot

    1. shiro的使用围绕着securityManager,权限需要从realm中来. securityManager可以设置realm或者realms,或者通过设置authenticator来设置r ...

  4. Java提升四:Stream流

    1.Stream流的定义 Stream是Java中的一个接口.它的作用类似于迭代器,但其功能比迭代器强大,主要用于对数组和集合的操作. Stream中的流式思想:每一步只操作,不存储. 2.Strea ...

  5. vue的MVVM

    Vue的相关知识有 字符串模板 MVVM 虚拟dom和domdiff,查看下一篇笔记 字符串模板 function render(template, data) { const reg = /\{\{ ...

  6. wdcp升级php5.8到php7.1.12后安装swoole

    http://pecl.php.net/package/swoole wget http://pecl.php.net/get/swoole-4.0.1.tgztar zxvf swoole-4.0. ...

  7. (一)微信小程序环境搭建

    1 注册 首先 打开(https://mp.weixin.qq.com/)微信公众平台官网 选着 小程序 之后 在新的页面选择 选着前往注册 按照提示注册 注意:个人版和企业版有一定的区别 2 开发者 ...

  8. B - Stacks of Flapjacks UVA - 120

    BackgroundStacks and Queues are often considered the bread and butter of data structures and find us ...

  9. 20170305深圳Meetup Rails中CSS,JS引用关系分析

    新手上路,若有错误请及时提醒 Rails中CSS,JS引用关系分析 一.Rails静态文件存放位置 二.Rails中CSS引用方式 三.Rails中JS引用方式与CSS类似 四.上面都是默认引用app ...

  10. netty权威指南学习笔记二——netty入门应用

    经过了前面的NIO基础知识准备,我们已经对NIO有了较大了解,现在就进入netty的实际应用中来看看吧.重点体会整个过程. 按照权威指南写程序的过程中,发现一些问题:当我们在定义handler继承Ch ...