亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

C語言實現最大間隙問題實例

2020-01-26 15:18:57
字體:
來源:轉載
供稿:網友

本文實例展示了C語言實現最大間隙問題的方法,對于算法的設計有一定的借鑒價值。分享給大家供大家參考。具體如下:

問題描述如下:

給定n個實數x1,x2,...,xn,求這n個實數在實軸上相鄰2個數之間的最大差值,要求設計線性的時間算法。

解決思路:

注意題中要求設計線性時間算法。如果沒有這個要求,就可以先排序,找出來就很方便。但我們知道排序最優良的算法的時間效率也是nlogn的。所以不可行。

采用一種區間算法。具體步驟就不說了,給出C語言代碼,有注釋加以說明。

具體實現代碼如下:

#include "stdio.h"#include "stdlib.h"#define MAX 10000float findmin(float data[],int n){/*尋找數據序列中的最小值*/   int index,i;   float min,temp;   temp=data[0];   for(i=1;i<n;i++){     if(data[i]<temp){       temp=data[i];       index=i;     }   }   min=data[index];   return min;}float findmax(float data[],int n){/*尋找數據序列中的最大值*/   int index,i;   float max,temp;   temp=data[0];   for(i=1;i<n;i++){     if(data[i]>temp){       temp=data[i];       index=i;     }   }   max=data[index];   return max;}void initial(int n,int count[],float low[],float high[],float min,float max){/*初始化區間*/   int i;   for(i=0;i<n;i++){     count[i]=0; //區間是否有數據存入      low[i]=max; //將區間的左端賦值最大值      high[i]=min; //將區間的右端復制最小值    }}void dataIn(float m,int count[],float low[],float high[],int n,float data[],float min){/*將數據序列依次放入對應區間*/   int i,location;   for(i=0;i<n;i++){     location=int((data[i]-min)/m)+1; //判斷數據進入哪個區間:按照等分區間,數據與最小值的差與區間大小的比值+1就是區間編號      if(location==n)       location--;     count[location]++; //有數據存入,計數值加1      if(data[i]<low[location]) //如果數據比左端值小,則作為左端值        low[location]=data[i];     if(data[i]>high[location]) //如果數據比右端值大,則作為右端值        high[location]=data[i];   }}float findMaxGap(int n,float low[],float high[],int count[]){ /*找出最大間隙,整個問題的核心*//*函數說明*//*上面已經把對應數據放入相應的區間,在之前可以知道,總共有n-1區間,相應的只有n-2個值,那么就一定有一個區間不會有數據*//*因為最大值與最小值已經分別被設為最小區間的左端值和最大區間的右端值,所以中間的n-1區間只有n-2個值*//*那么可以想象,最大間隙肯定不會是在一個區間中,而一定是在空區間的兩端,最大間隙為空區間右邊相鄰區間的左端值空區間左邊相鄰區間的右端值;有可能有多個這種情況,找出最大就行了*/   int i;   float maxgap,dhigh,temp;   dhigh=high[1];   for(i=2;i<n;i++){     if(count[i]){       temp=low[i]-dhigh;       if(maxgap<temp)         maxgap=temp;       dhigh=high[i];     }   }    return maxgap;}int main(){  float data[MAX];  int n,i=0;  float min,max;  float m,maxgap;  float low[MAX],high[MAX];  int count[MAX];  scanf("%d",&n);  for(i=0;i<n;i++)    scanf("%f",&data[i]);  min=findmin(data,n);  max=findmax(data,n);  m=(max-min)/(n-1);  initial(n,count,low,high,min,max);  dataIn(m,count,low,high,n,data,min);  maxgap=findMaxGap(n,low,high,count);  printf("%.1f",maxgap);  system("pause");  return 0;}

感興趣的朋友可以測試運行本文實例以加深理解。相信本文所述對大家C程序算法設計的學習有一定的借鑒價值。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品suv精品一区二区| 久国内精品在线| 中文字幕国内精品| 日韩成人中文字幕在线观看| 美日韩精品免费观看视频| 深夜福利国产精品| 久久久www成人免费精品| 亚洲影院色无极综合| 91精品国产精品| 日日噜噜噜夜夜爽亚洲精品| 色哟哟网站入口亚洲精品| 综合136福利视频在线| 俺去啦;欧美日韩| 色悠悠久久88| 97视频在线播放| 亚洲人精选亚洲人成在线| 国产亚洲精品美女| 成人深夜直播免费观看| 日韩精品极品视频免费观看| 日韩国产在线播放| 欧美精品电影在线| 91精品国产高清| 九九精品视频在线观看| 26uuu另类亚洲欧美日本老年| 91亚洲精品一区| 欧美激情视频网址| 国产精品永久免费| 久久偷看各类女兵18女厕嘘嘘| 亚洲日本成人女熟在线观看| 欧美最猛性xxxxx免费| 久久久久一本一区二区青青蜜月| 欧美日韩美女在线观看| 欧美色视频日本高清在线观看| 国产成人综合久久| 精品日韩美女的视频高清| 日韩电影免费观看在线观看| 精品欧美国产一区二区三区| 欧美日韩裸体免费视频| 国产精品久久99久久| 欧美日韩在线第一页| 国产精品网址在线| 成人观看高清在线观看免费| 黄色精品一区二区| 欧美裸身视频免费观看| 欧美电影电视剧在线观看| 欧美国产日韩在线| 亚洲国产精品女人久久久| 欧美xxxx18性欧美| 国产精品流白浆视频| 久久久999精品视频| 亚洲一区二区三区四区视频| 2019中文字幕在线免费观看| 亚洲欧美激情四射在线日| 91在线高清免费观看| 一本色道久久88综合亚洲精品ⅰ| 欧美国产第二页| 亚洲精品国产精品久久清纯直播| 在线精品国产欧美| 91久久综合亚洲鲁鲁五月天| 91wwwcom在线观看| 91在线视频免费| 成人免费黄色网| 91精品在线国产| 国产成人精品一区二区在线| 精品高清一区二区三区| 一个人www欧美| 国产日韩精品电影| 亚洲裸体xxxx| 欧美极品xxxx| 青青草99啪国产免费| 九九久久国产精品| 亚洲欧美综合区自拍另类| 亚洲色图综合网| 午夜美女久久久久爽久久| 91大神在线播放精品| 精品人伦一区二区三区蜜桃网站| 免费不卡欧美自拍视频| 欧美电影免费观看| 自拍偷拍亚洲一区| 国产99久久精品一区二区 夜夜躁日日躁| 中文字幕精品国产| 久久精品99久久香蕉国产色戒| 国产精品高清网站| 国产91热爆ts人妖在线| 97色在线播放视频| 国产在线观看一区二区三区| 久久久欧美一区二区| 亚洲xxxxx电影| 欧美黑人巨大精品一区二区| 亚洲日本欧美日韩高观看| 久久久久久久久亚洲| 成人精品视频久久久久| 欧美视频免费在线| 少妇av一区二区三区| 欧美电影免费观看| 国产精品久久一| 国产有码一区二区| 亚洲国产精品成人精品| 色中色综合影院手机版在线观看| 国产精品视频自在线| 日韩成人在线免费观看| 日韩中文字幕在线看| 欧美国产在线视频| 国产精品成人一区二区三区吃奶| 在线免费看av不卡| 国产91热爆ts人妖在线| 久久国产精品偷| 欧美日韩中文在线| 欧美在线视频免费观看| 久久精品成人一区二区三区| 久久久亚洲国产天美传媒修理工| 日韩av资源在线播放| 91成人天堂久久成人| 亚洲高清福利视频| 中文字幕一区二区精品| 亚洲色在线视频| 色偷偷av亚洲男人的天堂| 日韩性xxxx爱| 久久精品成人欧美大片| 日韩欧美国产黄色| 亚洲二区在线播放视频| 亚洲一区二区久久久久久| 一二美女精品欧洲| 国产精品视频精品| 国产欧美 在线欧美| 日韩免费在线免费观看| 亚洲精品国产精品国自产观看浪潮| 亚洲成人av资源网| 91av在线看| 日韩av综合中文字幕| 一区二区成人精品| 久久99国产精品久久久久久久久| 欧美有码在线视频| 亚洲电影免费观看高清完整版在线观看| 欧美激情a∨在线视频播放| 成人黄色在线播放| 最近日韩中文字幕中文| 国产精品99久久久久久久久| 欧美成人午夜激情视频| 亚洲最新av网址| 国产精品男女猛烈高潮激情| 日韩久久免费电影| 国产在线98福利播放视频| 欧美亚洲在线视频| 中文字幕亚洲激情| 91成品人片a无限观看| 亚洲午夜激情免费视频| 亚洲大胆人体av| 亚洲欧美成人一区二区在线电影| 美女黄色丝袜一区| 成年人精品视频| 国产综合色香蕉精品| 欧美日韩激情美女| 国产亚洲欧美视频| 欧美大奶子在线| 亚洲а∨天堂久久精品喷水| 日韩av免费看| 精品无人区太爽高潮在线播放| 亚洲国产精彩中文乱码av在线播放| 青青精品视频播放| 欧美精品中文字幕一区| 91精品视频专区| www.精品av.com| 亚洲第一区在线|