title: 2017-10-18控制流

tags: binsearch else-if, shellsort, insertsort

grammar_cjkRuby: true

前段时间忙着别的事情,不得不说政府部门办事真的很mj,自己的博客计划也就搁浅了,继续加油,不要被自己一点点的努力感动

else-if 折半查找binsearch

将待查找数据先和中间进行比较,如果待查找数据等于中间数据则直接返回,如果小于中间数则继续在前一半数据中进行判断,如果大于中间数则继续在后一半数据中进行判断。重复进行循环,直至搜索完数据。

/***********************/
//章节:第三章else-if
//内容:binsearch
/***********************/
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<sys/stat.h>
#include<time.h> #define MAX_ELEMENT 10000
#define LOOP 200000 int binsearch(int x,int v[],int n);//x is the element to search for ,n the length
int binsearch2(int x,int v[],int n); int main(void){
int testdate[MAX_ELEMENT];
int index; //index of element to search for
int n = 200; //element to search for
int i;
clock_t time_taken;//其实就是一个长整型,clock()返回程序运行的滴答数,要得到秒数则除以CLOCKS_PER_SEC
for(i = 0;i < MAX_ELEMENT; ++i){
testdate[i]=i;
//printf("%d\n", testdate[i]);
} for(i = 0,time_taken = clock();i < LOOP;++i){
index = binsearch(n,testdate,MAX_ELEMENT);
}
time_taken = clock() - time_taken;
if(index < 0)
printf("Element %d is not found in \n",n);
else
printf("Element %d is found at the index %d\n", n,index);
printf("binsearch() took %lu clocks[%lu seconds]\n",time_taken,time_taken/CLOCKS_PER_SEC); for(i = 0,time_taken = clock();i < LOOP;++i){
index = binsearch2(n,testdate,MAX_ELEMENT);
}
time_taken = clock() - time_taken;
if(index < 0)
printf("Element %d is not found in \n",n);
else
printf("Element %d is found at the index %d\n", n,index);
printf("binsearch2() took %lu clocks[%lu seconds]\n",time_taken,time_taken/CLOCKS_PER_SEC);
} int binsearch(int x,int v[],int n){
int low,mid,high;
low = 0;
high = n-1; while(low <= high){
mid = (low+high)/2;
if(x < v[mid])
high = mid - 1;
else if (x > v[mid])
low = mid + 1;
else
return mid;
}
return -1;
} int binsearch2(int x,int v[],int n){
int low,mid,high;
low = 0;
high = n-1;
mid = (low+high)/2; while(low <= high && x != v[mid]){
if(x < v[mid])
high = mid -1;
else
low = mid + 1;
mid = (low+high)/2;
}
if (x == v[mid])
return mid;
else
return -1;
}

插入排序

insertsort是最简单的排序方法,主要想法就是将一个新的数据插入已经排好顺序的序列中,从而获得一个长度加一的新序列。以下是一个简单的示意图。



希尔排序

希尔排序首先是将序列分为几组数据,然后依次对该组数据进行插入排序,然后不断组数不断减少,然后依次再对该组数据进行插入排序,我们把这个分组的个数叫增量,最后增量必须为1.

增量的取值规则为第一次取总长度的一半,第二次取一半的一半,直至增量为1

/***********************/
//章节:第三章控制流
//内容:shellsort,insertsort
/***********************/
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<sys/stat.h> void insertsort(int a[],int n){
int i,j,tmp;
for(i = 1; i < n;i++){
tmp = a[i];
for(j = i-1;j >= 0&&a[j] > tmp;j--)
a[j+1] = a[j];
a[j+1] = tmp;
}
} void shellsort(int a[],int n){
int i,j,gap,tmp;
for(gap = n/2 ; gap > 0 ; gap /= 2){
for(i = gap; i < n; i++){
tmp = a[i];
for(j = i - gap; j >= 0&&a[j] > tmp; j-=gap)
a[j+gap] = a[j];
a[j+gap] = tmp;
}
}
} int main(void){
int a[]={1,2,5,10,4,9,1,8},b[]={1,2,5,10,4,9,1,8};
int n,i;
n = 8;
insertsort(a,n);
for(i=0;i<n;i++){
printf("%d\n",a[i]);
}
printf(">>>>>>>>>>>>\n");
shellsort(b,n);
for(i=0;i<n;i++){
printf("%d\n",b[i]);
}
}

各种控制流语句

if else / else if

while

for

do while

switch case

goto sw; sw:语句 //跳出多层循环语句

C语言控制流语句的更多相关文章

  1. 带你学够浪:Go语言基础系列 - 8分钟学控制流语句

    ★ 文章每周持续更新,原创不易,「三连」让更多人看到是对我最大的肯定.可以微信搜索公众号「 后端技术学堂 」第一时间阅读(一般比博客早更新一到两篇) " 对于一般的语言使用者来说 ,20% ...

  2. (Python )控制流语句if、for、while

    这一节,我们将学习Python的控制流语句,主要包括if.for.while.break.continue 和pass语句 1. If语句 if语句也许是我们最熟悉的语句.其使用方法如下: x=inp ...

  3. OpenGL ES着色器语言之语句和结构体(官方文档第六章)内建变量(官方文档第七、八章)

    OpenGL ES着色器语言之语句和结构体(官方文档第六章) OpenGL ES着色器语言的程序块基本构成如下: 语句和声明 函数定义 选择(if-else) 迭代(for, while, do-wh ...

  4. 归纳整理Python中的控制流语句的知识点

    归纳整理Python中的控制流语句的知识点 Python 解释器在其最简单的级别,以类似的方式操作,即从程序的顶端开始,然后一行一行地顺序执行程序语句.例如,清单 1 展示了几个简单的语句.当把它们键 ...

  5. linux 几个控制流语句的格式例子(if语句)

    linux 几个控制流语句的格式例子:if 语句例子:#!/bin/sh a=10b=20 if [ $a == $b ]then echo "a is equal to b"el ...

  6. java基础-控制流语句

    浏览以下内容前,请点击并阅读 声明 一般情况下,代码的执行按照从上到下的顺序,然而通过加入一些判断,循环和跳转语句,你可以有条件地执行特定的语句. 接下来分三部分介绍Java的控制流语句,他们是判断语 ...

  7. [SQL]SQL语言入门级教材_SQL语言基本语句介绍(四)

    SQL语言基本语句介绍 • 表的建立 关系数据库的主要特点之一就是用表的方式组织数据.表是SQL语言存放数据.查找数据以及更新数据的基本数据结构.在SQL语言中,表有严格的定义,它是一种二维表,对于这 ...

  8. 【Python】控制流语句、函数、模块、数据结构

    1.三种控制流语句:if\for\while 2.每句后都要加冒号 3.有elif语句=else后加一个if 注意使用变量名! 注意缩进! 注意控制流语句后面要加冒号! 4.for i in rang ...

  9. T-SQL 控制流语句

    批处理: 一个批处理段是由一个或者多个语句组成的一个批处理,之所以叫批处理是因为所有语句一次性被提交到一个SQL实例. 批处理是分批提交到SQL Server示例,因此在不同的批处理里局部变量不可访问 ...

随机推荐

  1. javascript(js)创建对象的模式与继承的几种方式

    1.js创建对象的几种方式 工厂模式 为什么会产生工厂模式,原因是使用同一个接口创建很多对象,会产生大量的重复代码,为了解决这个问题,产生了工厂模式. function createPerson(na ...

  2. Hadoop(四)HDFS集群详解

    前言 前面几篇简单介绍了什么是大数据和Hadoop,也说了怎么搭建最简单的伪分布式和全分布式的hadoop集群.接下来这篇我详细的分享一下HDFS. HDFS前言: 设计思想:(分而治之)将大文件.大 ...

  3. hadoop配置文件详解,安装及相关操作

    一.      Hadoop伪分布配置 1. 在conf/hadoop-env.sh文件中增加:export JAVA_HOME=/home/Java/jdk1.6  2.  在conf/core-s ...

  4. Vue实现选项卡切换

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

  5. 全球多个 TOP 网站藏挖矿代码,5 亿 PC 沦为矿工

    据ZDNet报道,现在很多网站都开始在网页脚本中藏匿挖矿代码,在用户访问时偷算力用于挖矿.来自Adguard的报告称也证实,也有5亿台电脑中招. 最新最热的IT技术付费社区 IT帮 itbang.me ...

  6. 谦先生的bug日志之hive启动权限问题

    上海尚学堂谦先生的bug日志之hive启动权限问题 这几天开始做新老集群的迁移,今天开始对hive的所有数据进行迁移,主要是表的元信息和表数据.表的元信息我们存在mysql中,跟hive的服务器并不在 ...

  7. 2017年十大奇葩画风的H5页面案例,原来脑洞可以这样大

    每个人都是视觉动物,画面精美.体验奇特的H5,用户在内心一般都会满分打出,毫不吝啬,同时也毫不犹豫分享,因为此时的分享不掉价儿~ 今天给大家准备了十支H5,画风超级奇特,非常值得一看所有案例均可在19 ...

  8. ubuntu 13.04 64位安装32位兼容包

    未安装32位兼容包,编译出现未找到指定目录下gcc命令,则安装兼容包:sudo apt-get install ia32-libs 若提示:不能安装,与相关软件冲突,则按如下安装: 在网上找到更新源, ...

  9. Android基础知识06—活动的四大启动模式

    ------ 活动的启动模式 ------ 在实际项目中应该根据特定的需求为每个活动指定恰当的启动模式. 四种启动模式: standard . singleTop . singleTask . sin ...

  10. [Java第一课]环境变量的配置以及eclipse一些常用快捷键

    1.环境变量的配置(这里对xp系统电脑来说:) 首先安装jdk软件. 然后在我的电脑(右键)-->属性-->高级-->环境变量-->系统变量(注意)-->新建(新建两个p ...