高级语言课程设计报告第六次报告: 模拟

简介: 高级语言课程设计报告实习题目第六次报告: 模拟l 完成ACM俱乐部作业:2015cup实习6模拟中至少1道l 描述你的算法,注释你的程序。l 注意勿抄袭:全系统自动判定抄袭,一旦抄袭,0分。

高级语言课程设计报告

实习题目

第六次报告: 模拟

l 完成ACM俱乐部作业:2015cup实习6模拟中至少1

l 描述你的算法,注释你的程序。

l 注意勿抄袭:全系统自动判定抄袭,一旦抄袭,0分。

一、实习目的:熟练编程的算法及逻辑,了解不同题型的解法。

二、针对你的每一道题目:

李白打酒:

1.算法描述。

  确定最后两次肯定是喝酒后,进行13次循环每次循环两次分别进行两种情况,这样遍历每一种情况,然后用条件限制不行的情况,最后输出符合的情况。

2.你的代码及注释。

#include <stdio.h>

int main()

{

int a[16],b[16],c=0,d=0,e,f=0,g=0;

a[0]=2;

for(b[0]=0;b[0]<2;b[0]++)      //第一次动作

{

if(b[0]==0)

{

a[1]=a[0]*2;

c++;

}

else

{

a[1]=a[0]-1;

d++;

}

for(b[1]=0;b[1]<2;b[1]++) //第二次动作

{

if(b[1]==0)

{

a[2]=a[1]*2;

c++;

}

else

{

a[2]=a[1]-1;

d++;

if(a[2]==0) //判断酒量

break;

}

for(b[2]=0;b[2]<2;b[2]++) //第三次动作

{

if(b[2]==0)

{

a[3]=a[2]*2;

c++;

}

else

{

a[3]=a[2]-1;

d++;

if(a[3]==0) //判断酒量

  break;

}

for(b[3]=0;b[3]<2;b[3]++)  //第四次动作

{

if(b[3]==0)

{

a[4]=a[3]*2;

c++;

}

else

{

a[4]=a[3]-1;

d++;

if(a[4]==0) //依然判断酒量

  break;

}

for(b[4]=0;b[4]<2;b[4]++)    //第五次

{

if(b[4]==0)

{

a[5]=a[4]*2;

c++;

if(c==5) //总共打酒5次

  continue;

}

else

{

a[5]=a[4]-1;

d++;

if(a[5]==0) //依然判断酒量

  break;

}

for(b[5]=0;b[5]<2;b[5]++)    //第六次

{

if(b[5]==0)

{

a[6]=a[5]*2;

c++;

if(c==5) //总共打酒5次

  continue;

}

else

{

a[6]=a[5]-1;

d++;

if(a[6]==0) //依然判断酒量

  break;

}

for(b[6]=0;b[6]<2;b[6]++)    //第七次

{

if(b[6]==0)

{

a[7]=a[6]*2;

c++;

if(c==5) //总共打酒5次

  continue;

}

else

{

a[7]=a[6]-1;

d++;

if(a[7]==0) //依然判断酒量

  break;

}

for(b[7]=0;b[7]<2;b[7]++)    //第八次

{

if(b[7]==0)

{

a[8]=a[7]*2;

c++;

if(c==5) //总共打酒5次

  continue;

}

else

{

a[8]=a[7]-1;

d++;

if(a[8]==0) //依然判断酒量

  break;

}

for(b[8]=0;b[8]<2;b[8]++)    //第9次

{

if(b[8]==0)

{

a[9]=a[8]*2;

c++;

if(c==5) //总共打酒5次

  continue;

}

else

{

a[9]=a[8]-1;

d++;

if(a[9]==0) //依然判断酒量

  break;

}

for(b[9]=0;b[9]<2;b[9]++)    //第10次

{

if(b[9]==0)

{

a[10]=a[9]*2;

c++;

if(c==5) //总共打酒5次

  continue;

}

else

{

a[10]=a[9]-1;

d++;

if(d==10) //共喝了10次

  continue;

if(a==0) //依然判断酒量

  break;

}

for(b[10]=0;b[10]<2;b[10]++)    //第11次

{

if(b[10]==0)

{

a[11]=a[10]*2;          

c++;

if(c==5) //总共打酒5次

  continue;

}

else

{

a[11]=a[10]-1;  

d++;

if(d==10) //共喝了10次

  continue;

if(a==0) //依然判断酒量

  break;

}

for(b[11]=0;b[11]<2;b[11]++)    //第12次

{

if(b[11]==0)

{

a[12]=a[11]*2;

c++;

if(c==5) //总共打酒5次

  continue;

}

else

{

a[12]=a[11]-1;

d++;

if(d==10) //共喝了10次

  continue;

if(a[12]==0) //依然判断酒量

  break;

}

  for(b[12]=0;b[12]<2;b[12]++)    //第13次

  {

if(b[12]==0)

{

a[13]=a[12]*2;

c++;

if(c==5) //总共打酒5次

  continue;

}

else

{

a[13]=a[12]-1;

d++;

if(d==10) //共喝了10次

  continue;

if(a[13]==0) //依然判断酒量

  break;

}

a[14]=a[13]-1; //第14次

b[13]=1;

a[15]=a[14]-1; //第15次

b[14]=1;

for(e=0;e<15;e++) //数有几次成立

  if(b[e]==0)  g++;

if(a[15]==0&&g==5)    //成功就+1

{

  f++;

}

g=0;

}

}

}

}

}

}

}

}

}

}

}

}

}

printf("%d",f);   //输出个数

}

 

 

3. 设计及调试过程遇到的问题及解决方案。

 问题大概就是开始时如果某种情况不行要返回时出了问题,后来使用数组记录的每一步的酒量就省去了返回这一步,其次就是条件的设定总是出错,经过多次debug后终于成功。也是挺费劲的。

  1. 心得体会和自我对程序的评价

    我感觉这个完全不用我这么麻烦,直接用一个递归就行了,不用这么长,但是毕竟不习惯,就费了很大的劲复制粘贴,大的改了两次,就是因为酒量返回不了,不错的题目,相信下次在遇到我会试着用递归的方法。

十六进制转十进制:

1.算法描述。

 直接用%x输入。用%ld输出。此题bug在此。

2.你的代码及注释。

#include <stdio.h>

int main()

{

      long int a;

      scanf("%x",&a);

  printf("%ld",a);

}

 

 

3. 设计及调试过程遇到的问题及解决方案。

 此题需要long int,这是重点,不然答案错误。

4.心得体会和自我对程序的评价。

 我是不是有点太机智了。求老师放过。555555

约瑟夫:

1.算法描述。

2.你的代码及注释。

3. 设计及调试过程遇到的问题及解决方案。

4.心得体会和自我对程序的评价。

 

相关文章
|
2月前
|
运维 安全 测试技术
【答案】2023年国赛信息安全管理与评估正式赛答案-模块3 CTF
【答案】2023年国赛信息安全管理与评估正式赛答案-模块3 CTF
【答案】2023年国赛信息安全管理与评估正式赛答案-模块3 CTF
|
2月前
|
程序员 Python
揭秘单步调试:掌握这一技能让你代码无懈可击
揭秘单步调试:掌握这一技能让你代码无懈可击
23 0
|
2月前
|
人工智能
试了六个国内外的 AI 工具,做不对一道初中物理选择题
试了六个国内外的 AI 工具,做不对一道初中物理选择题
|
9月前
|
算法 程序员 编译器
当程序遇上困难:程序调试的艺术(VS)
当程序遇上困难:程序调试的艺术(VS)
51 0
|
前端开发
实验:CSS+Div基础 - 预习报告
网页设计技术实验预习报告。
197 1
实验:CSS+Div基础 - 预习报告
|
人工智能 运维 监控
热饭的测开成果盘点第二十三期:wqrfproxy自动抓包断言库
本期介绍的是一个组件,身为python的第三方库,已经被pypi收录,且国内镜像源也早已复制。也就是说可以通过pip install 来下载。这个组件就是:wqrfproxy ,它的作用是可以在正常的unittest脚本中,对app发出的请求进行断言。
热饭的测开成果盘点第二十三期:wqrfproxy自动抓包断言库
程序人生 - 九图带你全面读懂体检报告,超实用的阅读指南,马住!
程序人生 - 九图带你全面读懂体检报告,超实用的阅读指南,马住!
103 0
程序人生 - 九图带你全面读懂体检报告,超实用的阅读指南,马住!
|
Java 应用服务中间件 开发工具
很多未解之谜终于有答案了——2018年JVM生态系统报告出炉
在Java开发者中,一直存在着很多鄙视链。如: IntelliJ → Eclipse → NetBeans Unix → Linux → Mac OS→ Windows → DOS Emacs → Vim → Sublime → Word → Powe...
1011 0
|
架构师 Java 大数据
程序员如何跳出35岁魔咒,史上最全思维图收集解救你
时常有人在知乎、百度等平台抛出问题:程序员过了 35 岁或 40 岁是不是就失去了竞争力,要转管理岗了吗? 100offer 在2017年对其平台上的5844 位技术岗位求职者做了一个抽样调查,得出了如下统计结果: 10年以上的求职者,也就是“中年程序员”求职者的比例达到了10%,有了小幅攀升。
2072 0