云题海 - 专业文章范例文档资料分享平台

当前位置:首页 > 算法习题及解答

算法习题及解答

  • 62 次阅读
  • 3 次下载
  • 2025/12/2 22:06:06

到一个不同的颜色珠子,在另一端做同样的事。(颜色可能与在这之前收集的不同) 确定应该在哪里打破项链来收集到最大多数的数目的子。 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

搜索更多关于: 算法习题及解答 的文档
  • 收藏
  • 违规举报
  • 版权认领
下载文档10.00 元 加入VIP免费下载
推荐下载
本文作者:...

共分享92篇相关文档

文档简介:

到一个不同的颜色珠子,在另一端做同样的事。(颜色可能与在这之前收集的不同) 确定应该在哪里打破项链来收集到最大多数的数目的子。 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.i

× 游客快捷下载通道(下载后可以自由复制和排版)
单篇付费下载
限时特价:10 元/份 原价:20元
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信:fanwen365 QQ:370150219
Copyright © 云题海 All Rights Reserved. 苏ICP备16052595号-3 网站地图 客服QQ:370150219 邮箱:370150219@qq.com