GDKOI 2015 Day1 T2 单词统计Pascal
我虽然没有参加GDKOI2015,但是我找了2015年的题练了一下。
题意如下:


思路:最大流,因为有多组数据,每次读入一组数据都要清零。
a. 将每个点拆分成两个点,例如样例G→G`,再将字母一一编号,G=1,G`=2,D=3,D`=4……(公式:(x-1)*2*m+y*2{第x行,第y列}),将G与G`,D与D`等相连一条边,流量与cnt对应。

如图,如果w=GD,S为原点,F为汇点,构图如图。
b. 再向8个方向搜索是否有下一个字母,如有将它们之间连一条边,流量为无限。
c. 定原点为0,原点与第一个字母连一条边,流量为无限,定汇点n*m*2+1,最后一个字母与汇点相连一条边,流量为无限。
d. 建图完成之后,进行最大流计算。
代码如下:
program wordcount;
const x1:array[1..8] of longint=(-1,-1,-1,0,1,1,1,0);
y1:array[1..8] of longint=(-1,0,1,1,1,0,-1,-1);
var n,m,x,y,i,j,k,ans,z,nn,t,c,l,h,h2,head,tail:longint;
var s:ansistring;
var mat:array[1..510,1..510] of char;
var q:array[0..10000] of longint;
var flow:array[0..510,0..510] of longint;
var dis:array[0..510] of longint;
function hh(i,j:longint):longint;//公式函数
begin
exit((i-1)*2*m+j*2);
end;
function dfs(x,xx:longint):longint;//求最小流,增广之后得到最大流
var i,k:longint;
begin
if x=nn then exit(xx);
for i:=0 to nn do
if (flow[x,i]>0) and (dis[i]=dis[x]+1) then
begin
if flow[x,i]>xx then k:=dfs(i,xx) else k:=dfs(i,flow[x,i]);
dec(flow[x,i],k);inc(flow[i,x],k);
if k>0 then exit(k);
end;
exit(0);
end;
procedure bfs;//求dis(层)
var i,now:longint;
begin
fillchar(dis,sizeof(dis),0);
fillchar(q,sizeof(q),0);
dis[0]:=1;head:=1;tail:=1;q[1]:=0;
repeat
now:=q[head];
for i:=0 to nn do
if (flow[now,i]>0) and (dis[i]=0) then
begin
dis[i]:=dis[now]+1;
inc(tail);
q[tail]:=i;
end;
inc(head);
until head>tail;
end;//以上为最大流计算(d步)
begin
read(t);
for k:=1 to t do
begin
fillchar(q,sizeof(q),0);
fillchar(flow,sizeof(flow),0);
fillchar(dis,sizeof(dis),0);
for i:=1 to 210 do
for j:=1 to 210 do mat[i,j]:=chr(0);//以上为初始化
readln(n,m);nn:=n*m*2+1;
for i:=1 to n do
begin
readln(s);
for j:=1 to m do mat[i,j]:=s[j];
end;
for i:=1 to n do
for j:=1 to m do
begin
read(c);
flow[hh(i,j)-1,hh(i,j)]:=c;//连边
end;
readln;
readln(s);//以上为读入
for i:=1 to n do
for j:=1 to m do
begin
if mat[i,j]=s[1] then flow[0,hh(i,j)-1]:=maxlongint;//c步
if mat[i,j]=s[length(s)] then flow[hh(i,j),nn]:=maxlongint;//c步
h2:=pos(mat[i,j],s);
for l:=1 to 8 do //向8个方向搜索
begin
if (mat[i+x1[l],j+y1[l]]=s[h2+1]) then
flow[hh(i,j),hh(i+x1[l],j+y1[l])-1]:=maxlongint;
if (mat[i+x1[l],j+y1[l]]=s[h2-1]) then
flow[hh(i+x1[l],j+y1[l]),hh(i,j)-1]:=maxlongint;
end;
end;
ans:=0;
while 1=1 do
begin
bfs;
if dis[nn]=0 then break;
repeat
z:=dfs(0,maxlongint);
inc(ans,z);
until z>0;
end;
writeln('Case #',k,': ',ans);//注意输出格式
end;
end.
谢谢阅读!
因为此程序没有经过官方测评,只跟正解程序对拍了一下,可能会有些错,请在评论区告诉我。
另外,很抱歉,我不会打C++代码,请大家谅解。
GDKOI 2015 Day1 T2 单词统计Pascal的更多相关文章
- codevs 4511 信息传递(NOIP2015 day1 T2)
4511 信息传递 NOIP2015 day1 T2 时间限制: 1 s 空间限制: 128000 KB 传送门 题目描述 Description 有个同学(编号为 1 到)正在玩一个信息传递的游戏. ...
- 【NOIP2016 Day1 T2】天天爱跑步
题目传送门:https://www.luogu.org/problemnew/show/P1600 感觉这两天在处理边界问题上有点神志不清......为了从80的暴力变成100,花了整整一个下午+一个 ...
- [NOIP2016 DAY1 T2]天天爱跑步-[差分+线段树合并][解题报告]
[NOIP2016 DAY1 T2]天天爱跑步 题面: B[NOIP2016 DAY1]天天爱跑步 时间限制 : - MS 空间限制 : 565536 KB 评测说明 : 2s Description ...
- MapReduce 单词统计案例编程
MapReduce 单词统计案例编程 一.在Linux环境安装Eclipse软件 1. 解压tar包 下载安装包eclipse-jee-kepler-SR1-linux-gtk-x86_64.ta ...
- ytu 2002:C语言实验——单词统计(水题)
C语言实验——单词统计 Time Limit: 1 Sec Memory Limit: 64 MBSubmit: 61 Solved: 34[Submit][Status][Web Board] ...
- 2、 Spark Streaming方式从socket中获取数据进行简单单词统计
Spark 1.5.2 Spark Streaming 学习笔记和编程练习 Overview 概述 Spark Streaming is an extension of the core Spark ...
- hive学习之WordCount单词统计
看hive目录下就可以了,程序在hdfs里创建一个hive的大文件夹,相当于数据库吧.上面就是一个完整的利用hive来做单词统计,其中的优劣也能看出一点.
- scala基本语法和单词统计
scala 基本语法 1.声明变量 (1)val i = 1 使用val声明的变量值是不可变的,相当于java里final修饰的变量,推荐使用. (2)var i = "hello" ...
- 3728 联合权值[NOIP 2014 Day1 T2]
来源:NOIP2014 Day1 T2 OJ链接: http://codevs.cn/problem/3728/ https://www.luogu.org/problemnew/show/P1351 ...
随机推荐
- 用HTML和javascript(JS)计算触屏手机手指滑动方向的演示
移动终端的流行,程序员希望通过HTML+JS完成触屏动作的识别.下面给出具体实现的例子,供大家参考. 将下面的代码复制并保存,用手机访问,现在的手机浏览器一般都支持触屏,针对本演示来讲就是支持三个js ...
- [转载+实践理解]Android动画---如何正确使用平移动画(关于fillBefore和fillAfter的一点说明)(转载)
红色部分为自己的实践理解 如何实现将View向上平移自身高度一半的距离? TranslateAnimation translate = new TranslateAnimation( Animatio ...
- JS定时跳转URL并输出剩余秒数
1. [代码][JavaScript]代码 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 <scrip ...
- Visual Studio 2013中的“Browser Link”
前几天,参加了,VS13的新特性的讲座,回来便试了一下, 默认Html会引用如下脚本: <!-- Visual Studio Browser Link --> <script typ ...
- Moq让单元测试变得更简单
[ASP.Net MVC3 ]使用Moq让单元测试变得更简单 前几天调查完了unity.现在给我的任务是让我调查Moq. 以下是自己找了资料,总结并实践的内容.如果有表述和理解错误的地方.恳请指正. ...
- 企业架构与建模之使用ArchiMate进行分析
企业架构与建模之使用ArchiMate进行分析(全系列完) 4. 使用ArchiMate进行分析 正如前面所说的那样,一个企业整体效率的提升有时并不是通过某一个领域内的优化就能达到的,而且这种忽视全局 ...
- 高级SQL特性
SQL SQL 必知必会·笔记<20>高级SQL特性 摘要: 约束(constraint)就是管理如何插入或处理数据库数据的规则.DBMS通过在数据库表上施加约束来实施引用完整性.1. ...
- Js中call apply函数以及this用法
this介绍: C#里this关键字的意义比较确定的.JavaScript的this关键字,随着函数使用场合不同,this的值会发生变化,感觉用法比较混乱,所以,现在是有必要整理一下的时刻了! 总结一 ...
- 字符串比较strcmp
问题: 原型:extern int strcmp(const char *s1,const char * s2); 所在头文件:string.h 功能:比较字符串s1和s2. 一般形式:strcmp( ...
- mac在线恢复教程
上个周,我本来想升级一下Xcode,可是我的系统是10.8de,xcode5.0.1 最低支持10.8.4 所以就想升级一下我的mac的系统,可是因为我的appstore 是从别人的电脑上考过来的,要 ...