算法设计实验报告

上传人:ba****u6 文档编号:153217538 上传时间:2022-09-17 格式:DOCX 页数:8 大小:13.77KB
返回 下载 相关 举报
算法设计实验报告_第1页
第1页 / 共8页
算法设计实验报告_第2页
第2页 / 共8页
算法设计实验报告_第3页
第3页 / 共8页
点击查看更多>>
资源描述
算法设计与分析实验报告姓名:学号:班级:指导教师:实验一1, 分别用递归法和动态规划法求Fibonacci数,给出实2. 现代码,并填写下表:表1:F(N)的值F(N)N=2328657N=333524578N=43433494437N=484807526976表2:不同方法所用时间(ms)递归法动态规划其他N=23 时, 所用时间10N=33 时, 所用时间1370N=43 时, 所用时间168990N=48 时,所用时间2208130实现代码:递归算法:#include stdio.h#include conio.h#include time.hdouble fibonacci(int n)if(n=1lln=2)return 1;return fibonacci(n-1)+fibonacci(n-2);int main()int n;double p;clock_t start,end;scanf(%d,&n);start=clock();p=fibonacci(n);end=clock();printf(%f,p);printf(The different is %lf msn,(double)(end-start);system(pause);return 0;动态规划算法:#include stdio.h#include conio.h#include time.hlong fib(long n) long a,b,c;if(n=1) return n;a=1;b=0;for(int i=2;i=n;i+)c=a+b;b=a;a=c;return c;int main()long p;long q;clock_t start,end;scanf(%ld,&p);start=clock();q=fib(p);end=clock();printf(%ld,q);printf(The different is %lf msn,(float)(end-start);return 0;2.当问题规模N 100时,插入排序、快速排序和合并排序各需多少时间?写清机器配置,列出五种规模下各自需要的时间。按照下列表格提交:插入排序所需时间(ms)快速排序所需时间(ms)合并排序所需时间(ms)N=20010N=200040N=200004053N=2000004116542N=2000000566实现代码:插入排序和#include #include #include #include #define MAXSIZE 2000000typedef structdouble rMAXSIZE+1;int length;SqList,*PSqList;PSqList Init_PSeqList() PSqList PL;PL=(PSqList)malloc(sizeof(SqList);if(PL)PL-length=0;return (PL);void StraightInsertSort(SqList *S) int ij;for(i=2;ilength;i+)S-r0=S-ri;j=i-1;while(S-r0rj)S-rj+1=S-rj;j;S-rj+1=S-r0;main() int i,b,n;time_t start, finish;double elapsed_time;struct _timeb timebuffer;int startm, finishm;PSqList h;h=Init_PSeqList();printf( number:);scanf(%d,&n);h-length=n;srand( (unsigned)time( NULL );for( i = 0; i ri=rand();printf( %.0fn,h-ri);_ftime( &timebuffer );startm= timebuffer.millitm;start= timebuffer.time;printf( Working.n);StraightInsertSort(h);_ftime( &timebuffer );finishm= timebuffer.millitm;finish= timebuffer.time;elapsed_time = difftime( finish, start );elapsed_time= 1000* elapsed_time+ finishm-startm;printf( Program takes %.0f millisecondsnn, elapsed_time);快速排序算法:#include #include #include #include #define MAXSIZE 2000000typedef structint rMAXSIZE+1;int length;SqList,*PSqList;PSqList Init_PSeqList() PSqList PL;PL=(PSqList)malloc(sizeof(SqList);if(PL)PL-length=0;return (PL);int QuickSort1(SqList *S,int low,int high) int p;S-r0=S-rlow;p=S-rlow;while(lowhigh)while(lowrhigh=p) high-;S-rlow=S-rhigh;while(lowrlowrhigh=S-rlow;S-rlow=S-r0;return low;void QuickSort(SqList *S,int low,int high) int pi;if(lowlength=n;srand( (unsigned)time( NULL );for( i = 0; i ri=rand();printf( %dn,h-ri);_ftime( &timebuffer );startm= timebuffer.millitm;start= timebuffer.time;printf( Working.n);QuickSort(h,0,n-1);_ftime( &timebuffer );finishm= timebuffermillitm;finish= timebuffer.time;elapsed_time = difftime( finish, start );elapsed_time= 1000* elapsed_time+ finishm-startm;printf( Program takes %.0f millisecondsnnn, elapsed_time);合并排序算法:#define N 10000#include stdio.h#include conio.h#include#include void merge(int c,int d,int l,int m,int r)( int i=l;int j=m+1;int k=l;int q;while(iv=m)&(jv=r)if(cim)for(q=j;q=r;q+)dk+=cq;elsefor(q=i;q=m;q+) dk+=cq;void merge_sort(int a, int b ,int left, int right) int c10000;if(left=right) bright=aright;else int i=(left+right)/2;merge_sort(a,c,left,i);merge_sort(a,c,i+1, right);merge(c, b, left, i, right);int main()int cN,dN;long i;double m_time;clock_t m_start,m_end;for(i=0;iN;i+)ci=rand();m_start=clock();merge_sort( c, d,0,N-1);m_end=clock();m_time=(double)(m_end-m_start);printf(%ld个随机数进行归并排序用时%.0f毫秒n,N, m_time); return 0;
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 解决方案


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!