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