当前位置:首页 » 编程语言 » c语言直方图

c语言直方图

发布时间: 2024-05-29 22:04:27

c语言绘直方图

turboc 直方图

#include <math.h>
#include <conio.h>
#include <stdio.h>
#include <stdlib.h>
#include <graphics.h>

int main()
{
int GraphDriver;
int GraphMode;
int i, x, y;
char buffer[5];
int data[]={7,3,12,6,9,5,8,11};

GraphDriver = DETECT;
initgraph(&GraphDriver, &GraphMode, "");

setcolor(15);
moveto(635, 461);
lineto(20, 461);
lineto(20, 20);

setcolor(15);
for (i = 1 ; i < 13; i++)
{
itoa(i, buffer, 10);
outtextxy(20 - textwidth(buffer), 456 - i * 36, buffer);
moveto(20, 460 - i * 36);
lineto(23, 460 - i * 36);
}
setfillstyle(SOLID_FILL, 1);
for (i = 0 ; i < 8; i++)
{
moveto(i * 50 + 49, 461);
lineto(i * 50 + 49, 465);
outtextxy(i * 50 + 51, 463, itoa(i + 1, buffer, 10));
bar(i * 50 + 35, 460 - data[i] * 36, i * 50 + 65, 460);
}

getch();

closegraph();
}

② c语言编程设计直方图

#include<stdio.h>

voidDrawHistogram(intnArray[],intnCount,charch){
inti,j,m=0;
for(i=0;i<nCount;++i){
for(j=0;j<nArray[i];++j)
printf("%c",ch);
printf("%d ",nArray[i]);
}
printf(" ");
}

voidCountRangeItems(doubledArray[],intnDataItems,intnArray[]){
inti;
for(i=0;i<nDataItems;++i){
if(dArray[i]<=160)++nArray[0];
elseif(dArray[i]<165)++nArray[1];
elseif(dArray[i]<170)++nArray[2];
elseif(dArray[i]<175)++nArray[3];
elseif(dArray[i]>175)++nArray[4];
}
}

intmain(){
doubleheight[]={185,176,165,169,160,152,187,196,178,189,196,182,181,176,159,163,168};
intnArray[5]={0};
intnCount=0,size=sizeof(height)/sizeof(height[0]);
CountRangeItems(height,size,nArray);
DrawHistogram(nArray,5,'*');
return0;
}

③ C语言绘制直方图(C程序设计语言习题1-13)

你好,大概看了一下,这个好像是统计一段文字中单词的长度并绘制直方图。这里wl就是用来记录单词长度的。wl[i] = j 代表长度为i的单词有j个。
比如最开始,wl数组全是0:
wl = [0, 0, 0, 0, ...]
这个时候我们读入了一个长度为2的单词,于是wl[2]++,数组变成:(注意数组下标从0开始)
wl = [0, 0, 1, 0, ...]
如此往复就记录了所有单词的长度统计。

④ C语言 绘制水平直方图

#include <stdio.h>

#define MAXHIST 15 /*max length of histogram*/
#define MAXWORD 11 /*max length of a word*/
#define IN 1 /*inside a word*/
#define OUT 0 /*outside a word*/

/*print horizontal histogram*/
void main()
{
int c,i,nc,state;
int len; /*length of each bar*/
int maxvalue; /*maximum value for wl[]*/
int ovflow; /*number of overflow words*/
int wl[MAXWORD]; /*word length counters */

state=OUT;
nc=0; /*number of chars in a word*/
ovflow=0; /*number of words >=MAXWORD*/
for(i=0;i<MAXWORD;++i)
wl[i]=0; //初始化每个单词的长度为0
while((c=getchar())!=EOF) //从键盘获取字符串,并判断是否输入结束,结束应该是ctrl+z
{
if(c==' '||c=='\n'||c=='\t') //判断是否是一个单词(单词间都有间隔的)
{
state=OUT; //初始化状态为输出,表明这个单词已输入完成
if(nc>0) //判断这是不是一个单词
if(nc<MAXWORD)
++wl[nc]; //保存单词中字符的个数
else
++ovflow; //如果超过范围,则用ovflow保存字符数
nc=0;
}
else if(state==OUT) //如果上面的if不成立,则说明这个单词还没有输入完成
{
state=IN; //将状态设为IN,则表名这个单词没输入完成,还要继续输入。
nc=1; /*beginning of a new word*/
}
else //判断后面的字符是否是一个单词
++nc; /*inside a word*/
}
maxvalue=0;
for(i=1;i<MAXWORD;++i)
if(wl[i]>maxvalue)
maxvalue=wl[i];

for(i=1;i<MAXWORD;++i)
{
printf("%5d - %5d : ",i,wl[i]);
if(wl[i]>0)
{
if((len=wl[i]*MAXHIST/maxvalue)<=0)
len=1;
}
else
len=0;
while(len>0)
{
putchar('*');
--len;
}
putchar('\n');
}
if(ovflow>0)
printf("There are %d words>=%d\n",ovflow,MAXWORD);
}
//++wl[i];这个肯定可以的,wl[i]是一个数组变量,既然是个变量当然可以自增了。

⑤ 用c语言绘制直方图。。。急急急。。。。。。答案追加。。。。。

#include <graphics.h>
#include <stdlib.h>
#include <conio.h>
#include <stdio.h>

void main()
{
int driver=EGA,mode=1;
int data[]={7,3,12,6,9,5,8,11};
int i,j,xstep=70,ystep=20;
char buffer[10];
initgraph (&driver,&mode,"");
line(40,10,40,310);
line(40,310,540,310);
j=310;
settextjustify(CENTER_TEXT,CENTER_TEXT);
for(i=0;i<=15;i++)
{line(20,j,40,j);
itoa(i,buffer,10);
outtextxy(10,j,buffer);
j-=ystep;
}
j=40;
settextjustify(CENTER_TEXT,TOP_TEXT);
for(i=0;i<=8;i++)
{
setfillstyle(i+1,i+4);
line(j,320,j,310);
itoa(i,buffer,10);
outtextxy(j,330,buffer);
if(i!=8)
{
bar(j,(310-(data[i]*ystep)),j+xstep,310-1);
rectangle(j,(310-data[i]*ystep),j+xstep,310);
}
j+=xstep;
}
getch();
closegraph();
}

热点内容
opensslcmake编译 发布:2024-09-08 09:08:48 浏览:652
linux下ntp服务器搭建 发布:2024-09-08 08:26:46 浏览:743
db2新建数据库 发布:2024-09-08 08:10:19 浏览:172
频率计源码 发布:2024-09-08 07:40:26 浏览:779
奥迪a6哪个配置带后排加热 发布:2024-09-08 07:06:32 浏览:101
linux修改apache端口 发布:2024-09-08 07:05:49 浏览:209
有多少个不同的密码子 发布:2024-09-08 07:00:46 浏览:566
linux搭建mysql服务器配置 发布:2024-09-08 06:50:02 浏览:995
加上www不能访问 发布:2024-09-08 06:39:52 浏览:811
银行支付密码器怎么用 发布:2024-09-08 06:39:52 浏览:513