#include <stdio.h>
#include <time.h>//clock()所属头文件
const int N_qsort=;//快排的数据规模
const int M=,N=;//整点、浮点运算的规模
const int N_pi=;//计算圆周率的运算规模
double s_int,s_float,s_pi,s_sort;
void int_comp(void);//整点运算
void float_comp(void);//浮点运算
void pi_comp(void);//泰勒级数推论式计算圆周率
void Qsort(int a[],int low,int high);//快排算法
void qsort(void);//调用快排算法的函数
void panduan();
void PAUSE(); int main(){ printf("------\n性能测试开始\n");
int_comp();//整点运算
float_comp();//浮点运算
pi_comp();//泰勒级数推论式计算圆周率
qsort();//快速排序
printf("------\n测试结束\n");
printf("整点运算得分:%lf\n",s_int);
printf("泰勒级数推论式计算圆周率运算得分:%lf\n",s_pi);
printf("排序运算得分:%lf\n",s_sort);
printf("总得分:%lf\n",s_int+s_float+s_pi+s_sort);
panduan();
PAUSE();
} void int_comp(void){//整点加法
printf("整点运算测试中(运算次数为:%lf)\n",(double)M*N);
clock_t start,end;
int i,j;
start=clock();
for(i=;i<M;i++)
for(j=;j<N;j++);
end=clock();
double duration=(double)(end-start)/CLOCKS_PER_SEC;
double score=(M*N)/duration;
/*注:score本身即为运算速度,数量级一般在亿,为方便起见,本程序的分数均采用运算速度除以一万后的结果!除特殊说明,后面类同!*/
s_int=score/;
//printf("整点运算测试完毕!分数:%lf\n",s_int);
} void float_comp(void){//浮点加法
printf("浮点运算测试中(运算次数为:%lf)\n",(double)M*N);
clock_t start,end;
float i,j;
start=clock();
for(i=;i<M;i++)
for(j=;j<N;j++);
end=clock();
double duration=(double)(end-start)/CLOCKS_PER_SEC;
double score=(M*N)/duration;
s_float=score/;
//printf("浮点运算测试完毕!分数:%lf\n",s_float);
} void pi_comp(void){
printf("泰勒级数推论式计算圆周率中(运算次数为:%d)\n",N_pi);
int m,i=;
double s=;
clock_t start,end;
start=clock();
for(m=;m<N_pi;m+=){
s+=i*(1.0/m);
i=-i;
}
end=clock();
double duration=(double)(end-start)/CLOCKS_PER_SEC;
double score=N_pi/duration;
//下面一行可输出计算出来的圆周率
printf("pi=%lf\n",*s);
s_pi=score/;
//printf("泰勒级数推论式计算圆周率完毕!分数:%lf\n",s_pi);
}
void Qsort(int a[],int low,int high){//快排算法
if(low>=high) return;
int first=low;
int last=high;
int key=a[first];
while(first<last){
while(first<last&&a[last]>=key) --last;
a[first]=a[last];
while(first<last&&a[first]<=key) ++first;
a[last]=a[first];
}
a[first]=key;
Qsort(a,low,first-);
Qsort(a,first+,high);
}
void qsort(void){//调用快排算法的函数
int a[N_qsort],i;
for(i=N_qsort;i>;i--) a[N_qsort-]=i;
printf("排序运算中(对%d个数进行快速排序)\n",N_qsort);//采用最坏时间方案
clock_t start,end;
start=clock();
Qsort(a,,N_qsort-);
end=clock();
double duration=(double)(end-start)/CLOCKS_PER_SEC;
double score=(N_qsort*N_qsort)/duration;
s_sort=score/;
//printf("排序运算测试完毕!分数:%lf\n",s_sort);
}
void panduan(){
float i=s_int+s_float+s_pi+s_sort;
printf("根据分数,授予您的爱机<");
if (i>&&i<){
printf("渣渣");
}
else if (i>&&i<){
printf("低端");
}
else if (i>&&i<){
printf("中端");
}
else if (i>&&i<){
printf("高端");
}
else if (i>&&i<){
printf("超高端");
}
else if (i>){
printf("机皇");
}
printf(">称号\n");
}
void PAUSE(){
clean_stdin();
}

纯C语言跑分(详细注释)的更多相关文章

  1. 纯JavaScript实现俄罗斯方块(详细注释,ES6)

    借鉴了慕课网的课程<基于websocket的火拼俄罗斯(单机版)>虽然改动比较多,但是还是核心部分没有改,加了一些不怎么好听的声音,和看起来并不好看的界面. CSS部分基本是瞎写的,因为对 ...

  2. unixbench性能测试跑分工具

    UnixBench是一个类unix系(Unix,BSD,Linux)统下的性能测试工具,一个开源工具,被广泛用与测试linux系统主机的性能 所谓跑分工具,不仅各项的测试有得分,最后跑完也会有一个综合 ...

  3. 纯CSS实现侧边栏/分栏高度自动相等

    by zhangxinxu from http://www.zhangxinxu.com本文地址:http://www.zhangxinxu.com/wordpress/?p=694 一.为何要分栏高 ...

  4. MFC的PNG贴图按钮类(详细注释)

    MFC的PNG贴图按钮类(详细注释) (转载请注明出处) 作者:梦镜谷雨 萌新第二次写帖子,请多多包涵.末尾附上相应代码(PS公司繁体系统所以部分注释繁体请别介意). 因自带控件不美观,于是网上参考学 ...

  5. LINUX系统下跑分测试脚本:unixbench.sh

    linux 系统跑分测试脚本:     一.下载脚本:        wget http://teddysun.com/wp-content/uploads/unixbench.sh 二.更改权限:  ...

  6. VPS性能综合测试(6):UnixBench跑分工具测试

    测试时间可能会比较长,请耐心等待.最后UnixBench会详细列出各个测试项目的得分情况,以及VPS性能的综合跑分结果 UinxBench 的使用 使用方法如下: Run [ -q | -v ] [- ...

  7. Azure 进阶攻略 | 电脑跑分你会,但虚拟机存储性能跑分的正确姿势你造吗?

    想学生时代,小编最爱做的就是研究电脑硬件,然后给自己.朋友和童鞋装机.装好后呢?当然要第一时间跑分了!各种跑分软件运行一遍,不断优化,不断测试.终于得到一个满意成绩,截图分享到网上显摆一下.当年为啥就 ...

  8. geek青年的状态机,查表,纯C语言实现

    geek青年的状态机,查表,纯C语言实现 1. 问题的提出.抽象 建一,不止是他,不少人跟我讨论过这种问题:怎样才干保证在需求变更.扩充的情况下.程序的主体部分不动呢? 这是一个很深刻和艰难的问题.在 ...

  9. FastDFS是纯C语言实现,只支持Linux,适合以中小文件为载体的在线服务,还可以冗余备份和负载均衡

    一.理论基础 FastDFS比较适合以中小文件为载体的在线服务,比如跟NGINX(APACHE)配合搭建图片服务器. 分布式文件系统FastDFS FastDFS是纯C语言实现,只支持Linux.Fr ...

随机推荐

  1. 图示NP, P, NP-Complete和NP-Hard问题

    P问题是一类可以通过确定性图灵机(以下简称图灵机)在多项式时间(Polynomial time)内解决的问题集合. NP问题是一类可以通过非确定性图灵机( Non-deterministic Turi ...

  2. JavaIO流总结

    字节流 InputStream FileInputStream FilterInputStream BufferedInputStream DataInputStream PushbackInputS ...

  3. java翻译到mono C#实现系列(1) 重写返回键按下的事件

    今天看到群里的朋友问怎么按下返回键的时候提示信息,百度了下,就参考网上一个java版示例做了.没啥技术含量,就权当丰富下mono for android的小代码. 直接在mono新建的APP上修改的. ...

  4. Cloudera Manager安装之Cloudera Manager 5.3.X安装(三)(tar方式、rpm方式和yum方式)

    不多说,直接上干货! 福利每天都有  =>  =>=>=>=> 欢迎大家,关注微信扫码并加入我的4个微信公众号:   大数据躺过的坑      Java从入门到架构师  ...

  5. python2和python3中列表推导式的变量泄露问题

    Python 2.x 中,在列表推导中 for 关键词之后的赋值操作可能会影响列表推导上下文中的同名变量.像下面这个 Python 2.7 控制台对话: Python 2.7.15 (default, ...

  6. Unicode和UTF-8之间的转换

    转自:http://www.cnblogs.com/xdotnet/archive/2007/11/23/unicode_and_utf8.html#undefined 最近在用VC++开发一个小工具 ...

  7. NodeJS入门篇

    在我印象里,“全栈工程师”这个词是NodeJS诞生后才逐渐火起来的,因为NodeJS赋予了JS服务器开发的能力.下面开始从一个小白的角度进军NodeJS... 前言:在学习NodeJS之前是需要安装的 ...

  8. JavaScript函数——闭包

    闭包 概念 只有函数内部的子函数才能读取局部变量,所以闭包可以理解成"定义在一个函数内部的函数".在本质上,闭包是将函数内部和函数外部连接起来的桥梁 例子 function out ...

  9. 详解 Webpack+Babel+React 开发环境的搭建

    1.认识Webpack 构建应用前我们先来了解一下Webpack, Webpack是一个模块打包工具,能够把各种文件(例如:ReactJS.Babel.Coffeescript.Less/Sass等) ...

  10. Web开发者的福利 30段超实用CSS代码

    1.花式连字符(&) 这个类应该在span元素里使用,并且里面包括&字符.它使用经典的serif字体和斜体来增强&符号. .amp { font-family: Baskerv ...