第2周 项目3 - 体验复杂度
2015-09-11 09:27
363 查看
问题及代码:
复杂度是O(n 2 )的选择排序程序代码:
运行结果:
复杂度为O(nlogn) 的快速排序程序代码:
运行结果:
汉诺塔程序代码:
运行结果:
知识点总结:通过程序分析复杂度对于我们处理更复杂的程序有更多好处
/* * Copyright (c).2014, 烟台大学计算机学院 * All rights reserved. *文件名称:test.cpp *作 者:董子宾 *完成日期:2015年 9 月 11日 *版 本 号:v1.0 * *问题描述:体验复杂度是O(n 2 )的选择排序程序和复杂度为O(nlogn) 的快速排序程序 *问题输入:无 *问题输出:程序运行时间 */
复杂度是O(n 2 )的选择排序程序代码:
#include <stdio.h> #include <time.h> #include <stdlib.h> #define MAXNUM 100000 void selectsort(int a[], int n) { int i, j, k, tmp; for(i = 0; i < n-1; i++) { k = i; for(j = i+1; j < n; j++) { if(a[j] < a[k]) k = j; } if(k != j) { tmp = a[i]; a[i] = a[k]; a[k] = tmp; } } } int main() { int x[MAXNUM]; int n = 0; double t1,t2; FILE *fp; fp = fopen("numbers.txt", "r"); while(fscanf(fp, "%d", &x )!=EOF) n++; printf("数据量:%d, 开始排序....", n); t1=time(0); selectsort(x, n); t2=time(0); printf("用时 %d 秒!", (int)(t2-t1)); fclose(fp); return 0; }
运行结果:
复杂度为O(nlogn) 的快速排序程序代码:
#include <stdio.h> #include <time.h> #include <stdlib.h> #define MAXNUM 100000 void quicksort(int data[],int first,int last) { int i, j, t, base; if (first>last) return; base=data[first]; i=first; j=last; while(i!=j) { while(data[j]>=base && i<j) j--; while(data[i]<=base && i<j) i++; /*交换两个数*/ if(i<j) { t=data[i]; data[i]=data[j]; data[j]=t; } } data[first]=data[i]; data[i]=base; quicksort(data,first,i-1); quicksort(data,i+1,last); } int main() { int x[MAXNUM]; int n = 0; double t1,t2; FILE *fp; fp = fopen("numbers.txt", "r"); while(fscanf(fp, "%d", &x )!=EOF) n++; printf("数据量:%d, 开始排序....", n); t1=time(0); quicksort(x, 0, n-1); t2=time(0); printf("用时 %d 秒!", (int)(t2-t1)); fclose(fp); return 0; }
运行结果:
汉诺塔程序代码:
#include <stdio.h> #define discCount 4 long move(int, char, char,char); int main() { long count; count=move(discCount,'A','B','C'); printf("%d个盘子需要移动%ld次\n", discCount, count); return 0; } long move(int n, char A, char B,char C) { long c1,c2; if(n==1) return 1; else { c1=move(n-1,A,C,B); c2=move(n-1,B,A,C); return c1+c2+1; } }
运行结果:
知识点总结:通过程序分析复杂度对于我们处理更复杂的程序有更多好处
相关文章推荐
- 求并联电阻
- ERROR 1265 (01000): Data truncated for column 解决方法
- 收集整理比较全 shell sed 命令与实例教程
- Advanced R之构造子集
- phthon实现手机访问页面
- shell实现多进程,对数据库进行备份。
- 利用python多线程执行远程linux上命令
- mysqld异常重启后,自动启动应用srm进程
- Linux虚拟内存(VM)相关参数解析
- Linux内核OOM机制的详细分析
- 你知道 Linux 内核是如何构建的吗?
- 通过mk-table-checksum与pt-table-sync检查不同库两张表的一致性。
- MySQL多版本并发控制分析
- mysql导出存储过程、函数、视图、触发器
- InnoDB MVCC实现、Undo作用
- Mysql 索引概念及设计原则
- MySQL工具汇总
- mysql复制原理
- 数据库水平切分的实现原理解析
- Mysql数据表的优化