T1.笨小猴

  给出一个单词求出现次数最多和最少之差是不是质数。

   很水的。统计一下反正就26个字母。

T2.火柴棒等式

   给出火柴棒数,求形如 a+b=c能拼成的等式个数。

   先减去4根(+,=),然后枚举a,b,判断根数。

T3.传纸条

   给出一个矩阵,求左上角到右下角走两次(每个格子最多一次)能取得的最大值。

   首先可以写出f[i][j][k][l],为第一张走到i,j,另一张走到k,l时的最大值(因为可视为同时从1,1出发)。

   f[i][j][k][l]=max(f[i-1][j][k-1][l],f[i-1][j][k][l-1],f[i][j-1][k-1][l],f[i][j-1][k][l-1]);

   但是可以优化空间。因为i+j==k+l所以可以用f[x][y][z]表示共走了x步,第一张向下走了y步,另一张向下走了z步的情况。这种情况下要确保一张走过的另一张不能再走。所以代码如下(我打的??时间久了不记得了。。。)

  

 #include <iostream>
#include <algorithm>
using namespace std; int m,n,v[][],f[][][]; int main(){
cin >> m >> n;
for(int i=;i<=m;i++)
for(int j=;j<=n;j++)
cin >> v[i][j];
for(int i=;i<=m+n-;i++)
for(int j=;j<=i&&j<=m;j++)
for(int k=j;k<=i&&k<=m;k++)
{
if(j!=k||i==m+n-)
{
if(j<k-) f[i][j][k]=max(f[i][j][k],f[i-][j][k-]);
if(j-<k) f[i][j][k]=max(f[i][j][k],f[i-][j-][k]);
if(j-<k-) f[i][j][k]=max(f[i][j][k],f[i-][j-][k-]);
if(j<k) f[i][j][k]=max(f[i][j][k],f[i-][j][k]);
f[i][j][k]=f[i][j][k]+v[j][i-j+]+v[k][i-k+];
}
}
cout << f[m+n-][m][m] << "\n";
}

T4.双栈排序

   给出n个数的一种排列,求能否利用两个栈使出栈序列从小到大排序。

   这个要分步来,首先考虑单栈排序。一个栈要排序,必须不存在 (i<j<k 且  v[k]<v[i]<v[j])的情况

   那么双栈排序也是一样的,只是ij不能放到同一个栈里了。

   那么可以用二分图染色,ij之间连线。染色的时候如果冲突就无解。否则优先a,b,c,d,进行操作直到完全出栈。

   

 #include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <stack>
using namespace std; int n;
int a[];
int k[];
int nxt[],lst[],ed[],cnt;
int col[];
stack<int> q1,q2; void addedge(int a,int b)
{
nxt[++cnt]=lst[a];lst[a]=cnt;ed[cnt]=b;
nxt[++cnt]=lst[b];lst[b]=cnt;ed[cnt]=a;
} void dfs(int nw,int cl)
{
if (!col[nw])
col[nw]=cl;
else if(col[nw]!=cl)
{
cout << "0\n";
exit();
}
else
return;
for (int i=lst[nw];i;i=nxt[i]) dfs(ed[i],-cl);
} int main()
{
cin >> n;
for (int i=;i<=n;i++)
cin >> a[i];
k[n]=a[n];
for (int i=n-;i>=;i--)
k[i]=min(k[i+],a[i]);
for (int i=;i<=n;i++)
for (int j=i+;j<n;j++)
if (k[j-]<a[i] && a[j]>a[i])
addedge(i,j);
for (int i=;i<=n;i++)
if (!col[i])
dfs(i,);
int nww=,tt=;
while ()
{
if (nww>n) break;
if (col[tt]==&&(q1.empty()||q1.top()>a[tt]))
{
q1.push(a[tt]);
tt++;
cout << "a ";
continue;
}
if (!q1.empty() && q1.top()==nww)
{
cout << "b ";
nww++;
q1.pop();
continue;
}
if (col[tt]==&&(q2.empty()||q2.top()>a[tt]))
{
q2.push(a[tt]);
tt++;
cout << "c ";
continue;
}
if (!q2.empty() && q2.top()==nww)
{
cout << "d ";
nww++;
q2.pop();
continue;
}
}
return ;
}

noip2008解题报告的更多相关文章

  1. CH Round #56 - 国庆节欢乐赛解题报告

    最近CH上的比赛很多,在此会全部写出解题报告,与大家交流一下解题方法与技巧. T1 魔幻森林 描述 Cortana来到了一片魔幻森林,这片森林可以被视作一个N*M的矩阵,矩阵中的每个位置上都长着一棵树 ...

  2. 二模13day1解题报告

    二模13day1解题报告 T1.发射站(station) N个发射站,每个发射站有高度hi,发射信号强度vi,每个发射站的信号只会被左和右第一个比他高的收到.现在求收到信号最强的发射站. 我用了时间复 ...

  3. BZOJ 1051 最受欢迎的牛 解题报告

    题目直接摆在这里! 1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4438  Solved: 2353[S ...

  4. 习题:codevs 2822 爱在心中 解题报告

    这次的解题报告是有关tarjan算法的一道思维量比较大的题目(真的是原创文章,希望管理员不要再把文章移出首页). 这道题蒟蒻以前做过,但是今天由于要复习tarjan算法,于是就看到codevs分类强联 ...

  5. 习题:codevs 1035 火车停留解题报告

    本蒟蒻又来写解题报告了.这次的题目是codevs 1035 火车停留. 题目大意就是给m个火车的到达时间.停留时间和车载货物的价值,车站有n个车道,而火车停留一次车站就会从车载货物价值中获得1%的利润 ...

  6. 习题: codevs 2492 上帝造题的七分钟2 解题报告

    这道题是受到大犇MagHSK的启发我才得以想出来的,蒟蒻觉得自己的代码跟MagHSK大犇的代码完全比不上,所以这里蒟蒻就套用了MagHSK大犇的代码(大家可以关注下我的博客,友情链接就是大犇MagHS ...

  7. 习题:codevs 1519 过路费 解题报告

    今天拿了这道题目练练手,感觉自己代码能力又增强了不少: 我的思路跟别人可能不一样. 首先我们很容易就能看出,我们需要的边就是最小生成树算法kruskal算法求出来的边,其余的边都可以删掉,于是就有了这 ...

  8. NOIP2016提高组解题报告

    NOIP2016提高组解题报告 更正:NOIP day1 T2天天爱跑步 解题思路见代码. NOIP2016代码整合

  9. LeetCode 解题报告索引

    最近在准备找工作的算法题,刷刷LeetCode,以下是我的解题报告索引,每一题几乎都有详细的说明,供各位码农参考.根据我自己做的进度持续更新中......                        ...

随机推荐

  1. Allegro建立引脚封装概念名词梳理

    首先感谢于博士的60讲的Cadence教学视频,老师讲的还是很有耐心,很细致,谢谢! 目前还只是看到建立PCB封装这一块,正好手头上有个案子在做,边做边学的进度还是要好很多.以前的工作对原理图这一块的 ...

  2. CSS篇章

    页面的组成:页面=数据(后台技术jsp|asp|.net|php|python)+Html(显示)+CSS(样式)+js(动效) CSS:层叠样式表        特点:①CSS和HTML分离    ...

  3. ffmepg-nginx-nginx-rtmp-module配置脚本

    把上个月写的的配置脚本贴一下: #!/bin/bash #version:-- #create by itn #dis: this is used to auto install ffmpeg+ngi ...

  4. R读取数据的错误

    使用R读取数据的时候遇到这种错误: invalid multibyte string at '<fd>' 解决方法就是: tbl <- read.delim("dir/fi ...

  5. 判断表字段是否存在default约束

    sql语句 IF NOT EXISTS ( SELECT * FROM dbo.syscolumns WHERE id = OBJECT_ID('[dbo].[TActScoreReceiveRec] ...

  6. pooling方法修改方案

    http://blog.csdn.net/malefactor/article/details/51078135#0-tsina-1-38411-397232819ff9a47a7b7e80a4061 ...

  7. codeforces194a

    link:http://codeforces.com/contest/334/problem/A 很有意思的一道构造题.发现CF上经常出这种不难但是很不错的构造题. #include <iost ...

  8. ajax-1:基本实现原理

    一.什么是Ajax? Asynchronous JavaScript and XML(异步JavaScript和XML) 二.实现步骤 3.Open方法 三个参数的含义 1.提交方式 Form-met ...

  9. [转]STL中vector转数组(实际是数组的指针)

    感谢:http://topic.csdn.net/t/20050429/20/3976956.html 感谢:http://yzyanchao.blogbus.com/logs/47796444.ht ...

  10. QPS/QPS/PV/UV/服务器数量/并发数/吐吞量/响应时间计算公式

    QPS:每秒查询率(Query Per Second) ,每秒的响应请求数,也即是最大吞吐能力.QPS = req/sec = 请求数/秒QPS统计方式 [一般使用 http_load 进行统计]QP ...