C语言实型常量

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言实型常量相关的知识,希望对你有一定的参考价值。

不正确的实型常量是:
0.8103e 2
-77.77
讲讲为什么

我觉得这两个是正确的实型常量阿

引用如下:

严格来说,C语言中没有“实型”(real type)这种数据类型。
C语言中非构造类型只有整型(int、short、long、long long和对应的unsigned修饰的类型,以及同义写法),以及浮点型(包括单精度浮点型float,双精度浮点型double,长双精度浮点型long double)两大类。其中float和double内部储存形式遵循IEEE 754标准,long double取决于编译平台。C语言中的浮点型数内部储存形式为指数计数法分段存储的二进制形式的小数,即使在规定大小和字长精度范围之内也不能严格无误差地表示所有十进制小数、有理数,更不用说实数。(而C语言源代码中除了16进制整数表示的实际存储形式以外,直接表示的所有浮点数都只能是十进制的,因此除非在二进制下也是有限小数(分数形式中分母是2的幂),且不是太长,否则在编译过程中即会产生误差。)
尽管如此,有时候float、double、long double这三者(或者前两者)会被不严格地统称为“实型”。
C语言中,数值常量的后缀(大小写同义)可以表达常量的类型,例如0UL表示unsigned long型数0。如果没有后缀,则通过具体的写法来确定。总的原则是尽可能避免精度损失。不过也不是范围越小越好,例如0是int型而不是char型常量。对于没有后缀的十进制小数(小数部分或整数部分之一完全不写的也算,当作省略了0),默认为double常量,例如3.1415等同于3.1415D。(如果要用float常量,应该使用3.1415f或3.1415F。)对于指数形式的,默认也是double,例如0.329e2(或者0.329E+2之类的也可以)。至于0.329*10^2如果出现在源代码中,会被当做是一个表达式,先计算0.329和10的积,结果再和2作^(位异或)运算。但由于积是double类型的,不能参与位运算,会给出编译错误。
871是int常量,不是“实型”常量。
871.、871.f、871.0F、871.d、871.0D、8.71E+2、0.871e3这类才是“实型”常量。
回答者: 幻の上帝 - 十四级 2010-1-16 19:52
参考技术A 第一个错了,e或E后紧跟指数,他后面有一个空格。

数据结构c语言实现进栈出栈及遍历

进栈出栈及遍历

一、栈的定义和特点

1.定义:限制在表的一端进行插入和删除的线性表,其中允许插入删除的为栈顶,另外一个为栈底。
2.特点:先进后出

栈的示意图

二、定义结构体变量及主函数

代码如下(示例):

#include<stdio.h>
#include<malloc.h>
#include<stdlib.h> 

typedef struct Node
{
	int data;
	struct Node * pNext;
}N0DE , * PN0DE;


typedef struct Stack
{
	PN0DE pTop;
	PN0DE pBottom;
}STACK,* PSTACK;  // PStack等价于 struct Stack * 


void init (PSTACK);      //函数声明 
void push (PSTACK ,int );
void traverrse (PSTACK);



int main(void)
{
	STACK S; //等价于struct Stack 
	
	init(&S);//初始化 
	push(&S,1);//进栈操作
    traverrse(&S);//遍历操作 	
	return 0;
}
}

三、初始化栈

1.思路分析

创建一个栈元素用p-Top指向它,若为空则分配失败,跳出程序。
若初始化成功则ps->pBottom=ps->pTop并且ps->pTop的pNext为空

代码如下(示例):

void init (PSTACK ps)
{
	ps->pTop=(PN0DE)malloc(sizeof(N0DE)); 
	if(NULL==ps->pTop)
	{
		printf("动态内存分配失败\\n");
		exit(-1);
	}
	else
	{
		ps->pBottom=ps->pTop;
		ps->pTop->pNext=NULL; 
	}
}

2.示意图

在这里插入图片描述

四、进栈操作

1.思路分析

新建一个栈元素,给他的数值域赋值,原来的栈顶变为新元素的pNext,栈顶ps->pTop指向新元素。

代码如下(示例):

void push(PSTACK ps,int val)
{
	PN0DE pNew =(PN0DE)malloc(sizeof(N0DE));
	pNew->data=val;
	pNew->pNext=ps->pTop;
	ps->pTop=pNew;
	return;
}

2.示意图

在这里插入图片描述

五、遍历栈操作

定义一个临时变量p,让p等于栈顶元素,使用一个while循环,当p不等于栈底时循环输出元素的数据域,并且p指针下移。

代码如下(示例):


void traverrse (PSTACK ps)
 {	
	 PN0DE p =ps-> pTop;
	while (p!=ps->pBottom) 
  	{
			printf("%d",p->data);
			p=p->pNext;
  	}
 return;

总结

本次的内容简单的介绍了栈的定义和特点,并且进行了一些栈的基本操作。

以上是关于C语言实型常量的主要内容,如果未能解决你的问题,请参考以下文章

C语言实型常量

C语言实型常量

c语言中啥算是实型数据?举例子!

C语言中,实型常量是啥意思?啥概念?有啥用?

C语言浮点型数据能不能取余?

C语言关于浮点转换运算的问题