第一范文网 - 专业文章范例文档资料分享平台

算法习题及解答

来源:用户分享 时间:2025/9/28 0:06:19 本文由loading 分享 下载这篇文档手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:xxxxxxx或QQ:xxxxxx 处理(尽可能给您提供完整文档),感谢您的支持与谅解。

到一个不同的颜色珠子,在另一端做同样的事。(颜色可能与在这之前收集的不同) 确定应该在哪里打破项链来收集到最大多数的数目的子。 Exampl e 举例来说,在图片 A 中的项链,可以收集到8个珠子,在珠子 9 和珠子 10 或珠子 24 和珠子 25 之间打断项链。 在一些项链中,包括白色的珠子如图片 B 所示。 当收集珠子的时候,一个被遇到的白色珠子可以被当做红色也可以被当做蓝色。 表现项链的字符串将会包括三符号 r , b 和 w 。 写一个程序来确定从一条被供应的项链最大可以被收集珠子数目。

PROGRAM NAME: beads INPUT FORMAT

第 1 行: N, 珠子的数目

第 2 行: 一串度为N的字符串, 每个 字符是 r , b 或 w。

SAMPLE INPUT (file beads.in) 29

wwwbbrwrbrbrrbrbrwrwwrbwrwrrb OUTPUT FORMAT

单独的一行包含从被供应的项链可以被收集的珠子数目的最大值。 SAMPLE OUTPUT (file beads.out) 11 var

n,m:integer; s:string;

t,max:integer;

function cut():integer; var

i,j:integer; c:char; st:string; begin

st:=copy(s,m,n-m+1)+copy(s,1,m-1); i:=1;

while st[i]='w' do begin

i:=i+1; end;

c:=st[i];

for i:=1 to n do begin

if (st[i]<>c) and (st[i]<>'w') then begin

break; end; end; j:=n;

while st[j]='w' do begin

j:=j-1; end;

c:=st[j];

for j:=n downto 1 do begin

if (st[j]<>c) and (st[j]<>'w') then begin

break;

end; end;

cut:=i+n-j-1; end;

begin

assign(input,'beads.in'); assign(output,'beads.out'); reset(input); rewrite(output); readln(n); readln(s); max:=0;

for m:=1 to n do begin

t:=cut(); if max

搜索更多关于: 算法习题及解答 的文档
算法习题及解答.doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印
本文链接:https://www.diyifanwen.net/c36bzl7jmt39acj39pw8k_5.html(转载请注明文章来源)
热门推荐
Copyright © 2012-2023 第一范文网 版权所有 免责声明 | 联系我们
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:xxxxxx 邮箱:xxxxxx@qq.com
渝ICP备2023013149号
Top