计算机类竞赛题讲述.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
计算机类竞赛题讲述

数学与计算机学院 上机报告 ( 2015 / 2016 学年 第 2 学期 ) 课程名称 计算机类竞赛专题训练 课程代码 上机时间 2016 年 03 月 29 日 指导单位 计算机与软件工程学院 任课教师 蒋忠远 学生姓名 蒋琦 年 级 2013级 学 号 3120130901327 专 业 计算机科学与技术 成 绩 实验名称 上机ACM习题练习 实验地点 6A-403 实验类型 实验学时 2 实验日期 2016.03.29 实验目的和要求 实验目的: 1. 掌握部分ACM竞赛题的算法。 实验要求: 1.给出一个由O和X组成的串(长度为1~80),统计得分。每个O的得分为目前连续出现的O的个数,X的得分为0.例如,OOXXOXXOOO的得分为1+2+0+0+1+0+0+1+2+3. 2.输入整数a和b(0=a=3000,1=b=3000),输出a/b的循环小数表示以及循环节长度。例如a=5,b=43,小数表示为0.(116279069767441860465),循环节长度为21. 3.输入两个字符串s和t,判断是否可以从t中删除0个或多个字符(其他字符顺序不变),得到字符串s。例如,abcde可以得到bce,但无法得到dc。 4.编写一个“裁判”程序,输入单词和玩家的猜测,判断玩家赢了(You win.)、输了(You lose.)还是放弃了(You chickened out.)。每组数据包含3行,第1行是游戏编号(-1为输入结束标记),第2行是计算机想的单词,第3行是玩家的猜测。后两行保证只含小写字母。 实验环境(实验设备) Windows 7 + Visual C++ 6.0 实验原理及内容 1.实验原理 1、创建2个字符串一个用于存放字符串,一个用于存放需要相加的大小,判断第一个元素为0还是1.然后使用循环当遇到O时所数组的值便在前一个的基础上加1当遇到X时归0继续计算。最后将存放大小的数组全部相加。 2、一直相除,当遇到商相同的时候说明为一个循环,然后计算长度。 3、短串的第一个字符,去比较长传的第一个字符,如果相同,则转向短串的下一个字符,去个长串的下一个字符比较,如果不同,则接着和长串的下一个字符比较,重复这样的过程,次数为长串的长度,如果能够遍历短串的长度。则成功,否则失败。 4、通过两个变量来判断游戏的输赢,经过循环来查看字母是否猜对,将猜对的字母改成空格。 2.实验内容 1.给出一个由O和X组成的串(长度为1~80),统计得分。每个O的得分为目前连续出现的O的个数,X的得分为0.例如,OOXXOXXOOO的得分为1+2+0+0+1+0+0+1+2+3. 2.输入整数a和b(0=a=3000,1=b=3000),输出a/b的循环小数表示以及循环节长度。例如a=5,b=43,小数表示为0.(116279069767441860465),循环节长度为21. 3.输入两个字符串s和t,判断是否可以从t中删除0个或多个字符(其他字符顺序不变),得到字符串s。例如,abcde可以得到bce,但无法得到dc。 4.编写一个“裁判”程序,输入单词和玩家的猜测,判断玩家赢了(You win.)、输了(You lose.)还是放弃了(You chickened out.)。每组数据包含3行,第1行是游戏编号(-1为输入结束标记),第2行是计算机想的单词,第3行是玩家的猜测。后两行保证只含小写字母。 3.实验前准备 打开vc++6.0,建立相关控制台应用程序,为编程做准备。 4.实验过程 1.给出一个由O和X组成的串(长度为1~80),统计得分。每个O的得分为目前连续出现的O的个数,X的得分为0.例如,OOXXOXXOOO的得分为1+2+0+0+1+0+0+1+2+3. #includeiostream using namespace std; int main() { char a[100]; int b[110]; int n; cinn; while(n--) { cina; b[0]=(a[0]==O); for(int i=1;a[i];i++) { b[i]=b[i-1]+1; if(a[i]==X) b[i]=0; } int sum=0; for(int i=0;a[i];++i) sum+=b[i]; coutsum; } return 0; } 2.输入整数a和b(0=a=3000,1=b=3000),输出a/b的循环小数

文档评论(0)

jiayou10 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8133070117000003

1亿VIP精品文档

相关文档