实验一:求整数和、铺地板和Hanoi塔等问题的求解

2023-12-26 09:59

本文主要是介绍实验一:求整数和、铺地板和Hanoi塔等问题的求解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实验一:求整数和、铺地板和Hanoi塔等问题的求解

一、问题描述

  1. 整数求和: 从1到n之间的整数相加,和是多少? 用C语言实现函数,输入n,返回和;
  2. 铺地板问题: 在2×n的矩形中铺入1×2大小的地板,求其有多少种铺法;
  3. Hanoi塔问题: 一次只能移动一层,大的不能放在小的上面。可以使用临时场所 暂存中间结果。移动n层的塔,总的移动次数是多少?;

二、实验描述

  1. 用C语言编程实现求整数平方和、铺地板和Hanoi等问题的求解;
  2. 在程序中加入clock()来计算求解时间;
  3. 使用不同的输入值得到对应的时间值;
  4. 分析算法的时间复杂度并与测量结果比较;
  5. 如果存在差异,分析原因;

三、实验设计

  1. 求整数平方和问题:
    迭代:
    1) 定义函数sum(int n),利用for循环迭代求解前n项整数平方和
    2) 在main函数中定义int型变量j,通过for循环,以j*100作为参数调用sum函数,让j递增,依次计算前1000、2000、3000,…10000的平方和
    3) 定义clock_t类型变量start_time和end_time,调用clock()函数来记录函数开始和结束的执行时间
    4) 打印(double)(end_time-start_time)
    5) 重复5次实验,取平均值
    6) 记录实验数据并绘制Excel图表
  2. 铺地板问题:
    1) 定义函数flour(int n),设定n=1与n=2时的基准情形(flour(1)=1,flour(2)=2),利用递归式flour(n)=flour(n-1)+flour(n-2)求解铺地板的铺法
    2)在main函数中定义int型变量j,通过for循环,以j作为参数调用flour函数,让j递增,依次计算n为30、40、50,…39的铺法
    3)定义clock_t类型变量start_time和end_time,调用clock()函数来记录函数开始和结束的执行时间
    4)打印(double)(end_time-start_time)
    5)重复5次实验,取平均值
    6)记录实验数据并绘制图表
    3.Hanoi塔问题:
    1)定义函数HanoiTower(int n,char source,char, temp,char target),设定n=1时为基准情形,利用递归式S(n)=2*S(n-1)+1求解n层塔的移动次数(S(n)为n层塔的移动次数)
    2)在main函数中定义int型变量n并通过scanf()操作得到值作为求Hanoi塔层数的函数参数
    3)定义clock_t类型变量start_time和end_time,调用clock()函数来记录函数开始和结束的执行时间
    4)打印(double)(end_time-start_time)
    5)重复5次实验,取平均值
    6)记录实验数据并绘制图表

四、实验实现过程

  1. 求整数平方和问题:
    迭代:
    1) 定义函数sum(int n),利用for循环迭代求解前n项整数平方和
    2) 在main函数中定义int型变量j,通过for循环,以j*100作为参数调用sum函数,让j递增,依次计算前1000、2000、3000,…10000的平方和
    3) 定义clock_t类型变量start_time和end_time,调用clock()函数来记录函数开始和结束的执行时间
    4) 打印(double)(end_time-start_time)
    5) 重复5次实验,取平均值
    6) 记录实验数据并绘制Excel图表
#include<stdio.h>
#include<math.h>
#include<time.h>
#include<stdlib.h>void sum(int n){int res = 0;for(int i=1;i<=n;i++){res = res+i*i;}
}
int main()
{clock_t start_time,end_time;for(int j=1;j<=10;j++){start_time=clock();for(int k=0;k<10000;k++){sum(j*1000);}end_time=clock();printf("%f\n",(double)(end_time-start_time));}return 0;
}
  1. 铺地板问题
    1) 定义函数flour(int n),设定n=1与n=2时的基准情形(flour(1)=1,flour(2)=2),利用递归式flour(n)=flour(n-1)+flour(n-2)求解铺地板的铺法
    2)在main函数中定义int型变量j,通过for循环,以j作为参数调用flour函数,让j递增,依次计算n为30、40、50,…39的铺法
    3)定义clock_t类型变量start_time和end_time,调用clock()函数来记录函数开始和结束的执行时间
    4)打印(double)(end_time-start_time)
    5)重复5次实验,取平均值
    6)记录实验数据并绘制图表
#include<stdio.h>
#include<math.h>
#include<time.h>
#include<stdlib.h>int flour(int n){if((n==1)||(n==2)){return 1;}else{return (flour(n-1)+flour(n-2));}
}
int main()
{clock_t start_time,end_time;for(int j=30;j<40;j++){start_time=clock();flour(j);end_time=clock();printf("%f\n",(double)(end_time-start_time));}return 0;
}

3.Hanoi塔问题:
1)定义函数HanoiTower(int n,char source,char, temp,char target),设定n=1时为基准情形,利用递归式S(n)=2*S(n-1)+1求解n层塔的移动次数(S(n)为n层塔的移动次数)
2)在main函数中定义int型变量n并通过scanf()操作得到值作为求Hanoi塔层数的函数参数
3)定义clock_t类型变量start_time和end_time,调用clock()函数来记录函数开始和结束的执行时间
4)打印(double)(end_time-start_time)
5)重复5次实验,取平均值
6)记录实验数据并绘制图表

#include<stdio.h>
#include<math.h>
#include<time.h>
#include<stdlib.h>//int i=0;
void HanoiTower(int n,char source,char temp,char target){if(n==1){printf("%c->%c\n",source,target);//i++;}else{HanoiTower(n-1,source,target,temp);printf("%c->%c\n",source,target);//i++;HanoiTower(n-1,temp,source,target);}
}
int main()
{int n;clock_t start_time,end_time;char source='A',temp='B',target='C';scanf("%d",&n);start_time=clock();HanoiTower(n,source,temp,target);end_time=clock();printf("%f",(double)(end_time-start_time));//printf("总移动次数为:%d\n",i);return 0;
}

五、实验结果

  1. 求整数平方和问题图表
    在这里插入图片描述
    在这里插入图片描述
  2. 铺地板问题
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
  3. Hanoi问题
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

六、实验结论

  1. 算法时间复杂度的分析
    对于迭代法求前n个整数的平方和,其时间复杂度T(n)=O(n);对于递归法求铺地板,其时间复杂度T(n)=T(n-1)+T(n-2),T(1)=T(2)=1,T(n)=O(2n); 对于Hanoi塔问题使用递归,有T(n)=2×T(n-1)+1,T(1)=1,消去系数和常量可得T(n)=O(2n);

  2. 与测量结果进行比对
    求前n个整数的平方和问题得到的结果曲线为一条直线,说明n与时间t成线性关系,与算法的时间复杂度分析所得的T(n)=O(n)吻合;铺地板问题和Hanoi塔问题的结果曲线中,n与log(t)大致成线性关系,与时间复杂度分析吻合。曲线存在误差可能与CPU的内存分配与运行速度有关,n呈指数形式增长,递归占用的内存也迅速增加,大到一定规模时,必将影响运行时间

这篇关于实验一:求整数和、铺地板和Hanoi塔等问题的求解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/538990

相关文章

Redis 热 key 和大 key 问题小结

《Redis热key和大key问题小结》:本文主要介绍Redis热key和大key问题小结,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、什么是 Redis 热 key?热 key(Hot Key)定义: 热 key 常见表现:热 key 的风险:二、

IntelliJ IDEA 中配置 Spring MVC 环境的详细步骤及问题解决

《IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决》:本文主要介绍IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决,本文分步骤结合实例给大... 目录步骤 1:创建 Maven Web 项目步骤 2:添加 Spring MVC 依赖1、保存后执行2、将新的依赖

Spring 中的循环引用问题解决方法

《Spring中的循环引用问题解决方法》:本文主要介绍Spring中的循环引用问题解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录什么是循环引用?循环依赖三级缓存解决循环依赖二级缓存三级缓存本章来聊聊Spring 中的循环引用问题该如何解决。这里聊

Spring Boot中JSON数值溢出问题从报错到优雅解决办法

《SpringBoot中JSON数值溢出问题从报错到优雅解决办法》:本文主要介绍SpringBoot中JSON数值溢出问题从报错到优雅的解决办法,通过修改字段类型为Long、添加全局异常处理和... 目录一、问题背景:为什么我的接口突然报错了?二、为什么会发生这个错误?1. Java 数据类型的“容量”限制

关于MongoDB图片URL存储异常问题以及解决

《关于MongoDB图片URL存储异常问题以及解决》:本文主要介绍关于MongoDB图片URL存储异常问题以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录MongoDB图片URL存储异常问题项目场景问题描述原因分析解决方案预防措施js总结MongoDB图

SpringBoot项目中报错The field screenShot exceeds its maximum permitted size of 1048576 bytes.的问题及解决

《SpringBoot项目中报错ThefieldscreenShotexceedsitsmaximumpermittedsizeof1048576bytes.的问题及解决》这篇文章... 目录项目场景问题描述原因分析解决方案总结项目场景javascript提示:项目相关背景:项目场景:基于Spring

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

usb接口驱动异常问题常用解决方案

《usb接口驱动异常问题常用解决方案》当遇到USB接口驱动异常时,可以通过多种方法来解决,其中主要就包括重装USB控制器、禁用USB选择性暂停设置、更新或安装新的主板驱动等... usb接口驱动异常怎么办,USB接口驱动异常是常见问题,通常由驱动损坏、系统更新冲突、硬件故障或电源管理设置导致。以下是常用解决

Mysql如何解决死锁问题

《Mysql如何解决死锁问题》:本文主要介绍Mysql如何解决死锁问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录【一】mysql中锁分类和加锁情况【1】按锁的粒度分类全局锁表级锁行级锁【2】按锁的模式分类【二】加锁方式的影响因素【三】Mysql的死锁情况【1

SpringBoot内嵌Tomcat临时目录问题及解决

《SpringBoot内嵌Tomcat临时目录问题及解决》:本文主要介绍SpringBoot内嵌Tomcat临时目录问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录SprinjavascriptgBoot内嵌Tomcat临时目录问题1.背景2.方案3.代码中配置t