1、enum 枚举的定义
枚举类型定义的一般形式为:
enum 枚举名{ 枚举值表 };
在枚举值表中应罗列出所有可用值。这些值也称为枚举元素。
例如:
该枚举名为weekday,枚举值共有7个,即一周中的七天。凡被说明为weekday类型变量的取值只能是七天中的某一天。
2、枚举变量的说明
如同结构和联合一样,枚举变量也可用不同的方式说明,即先定义后说明,同时定义说明或直接说明。
设有变量a,b,c被说明为上述的weekday,可采用下述任一种方式:
enum weekday{ sun,mou,tue,wed,thu,fri,sat };
enum weekday a,b,c;
或者为:
enum weekday{ sun,mou,tue,wed,thu,fri,sat }a,b,c;
或者为:
enum { sun,mou,tue,wed,thu,fri,sat }a,b,c;
3、枚举类型变量的赋值和使用
枚举类型在使用中有以下规定:
a 枚举值是常量,不是变量。不能在程序中用赋值语句再对它赋值。
例如对枚举weekday的元素再作以下赋值:
sun=5;
mon=2;
sun=mon;
都是错误的。
b 枚举元素本身由系统定义了一个表示序号的数值,从0开始顺序定义为0,1,2…。如在weekday中,sun值为0,mon值为1,…,sat值为6。
int main(){
enum weekday
{ sun,mon,tue,wed,thu,fri,sat } a,b,c;
a=sun;
b=mon;
c=tue;
printf("%d,%d,%d",a,b,c);
return 0;
}
说明:
只能把枚举值赋予枚举变量,不能把元素的数值直接赋予枚举变量。如:
a=sum;
b=mon;
是正确的。而:
a=0;
b=1;
是错误的。如一定要把数值赋予枚举变量,则必须用强制类型转换。
如:a=(enum weekday)2;
其意义是将顺序号为2的枚举元素赋予枚举变量a,相当于:
a=tue;
还应该说明的是枚举元素不是字符常量也不是字符串常量,使用时不要加单、双引号。
int main(){
enum body
{ a,b,c,d } month[31],j;
int i;
j=a;
for(i=1;i<=30;i++){
month[i]=j;
j++;
if (j>d) j=a;
}
for(i=1;i<=30;i++){
switch(month[i])
{
case a:printf(" %2d %c\t",i,'a'); break;
case b:printf(" %2d %c\t",i,'b'); break;
case c:printf(" %2d %c\t",i,'c'); break;
case d:printf(" %2d %c\t",i,'d'); break;
default:break;
}
}
printf("\n");
return 0;
}
楼上的递归实现确实不错,但是坏处是不方便将所有的排列组合结果保存起来,除非用上全局变量或静态变量。
如果nCount是固定的,问题就会变得非常简单,比如当nCount=3的时候,用上3个for循环即可。我借用宏来简化定义不同nCount情况下的代码,没有楼上的递归函数方法高明,但是执行效率应该会更高些,且方便收集所有的组合结果。
void combineAll(int a[], int nBegin, int nEnd, int nCount)
{
int buf = new int[nCount 2 + 1];
int end = buf, arr = buf + nCount + 1; //int end[nCount]; int arr[nCount+1];
end[0] = nEnd - nCount + 1;
for(int k = 1; k < nCount; k++)
end[k] = end[k - 1] + 1;
arr[-1] = nBegin - 1;
#define LOOP(k) for(arr[k] = arr[k - 1] + 1; arr[k] < end[k]; arr[k]++)
#define STORE { for(int k = 0; k < nCount; k++) printf("%d", a[arr[k]]); printf(" "); } //or we can push a[arr[0~nCount]] to a vector
switch(nCount) {
case 1:
LOOP(0) STORE break;
case 2:
LOOP(0) LOOP(1) STORE break;
case 3:
LOOP(0) LOOP(1) LOOP(2) STORE break;
case 4:
LOOP(0) LOOP(1) LOOP(2) LOOP(3) STORE break;
case 5:
LOOP(0) LOOP(1) LOOP(2) LOOP(3) LOOP(4) STORE break;
default:
throw; //or we can use a recursive function
}
#undef LOOP
#undef STORE
delete[] buf;
}
int main()
{
int a[] = { 0,1,2,3,4,5 };
int nBegin = 0, nEnd = 6, nCount = 3;
PrintAll(a, nBegin, nEnd - 1, nCount, "");
printf("\n--------------------\n");
combineAll(a, nBegin, nEnd, nCount);
return getchar();
}
枚举实际上相当于整型常量。如果语言不支持枚举,可以这样。如:
typedef const int SPEED;
const int WALK=0;
const int RUN=1;
但是,C++是兼容C的。所以你可以用枚举。之所以用0、1会有警告,是因为C++的类型检查要严格一些。你写WALK的话它知道这是enum SPEED类型了,你写0、1的话他就认为这是普通的整型了,所以会提示警告让你转换类型。
既然你用了枚举,就彻底用枚举,不要一会用WALK,一会用0,不要因为懒得多敲3个字母就用0
#include <stdioh>
enum
{
Qi=1,//企划部
Cai,//财务部
Ren,//人力资源部
Shi,//市场部
};
main()
{
int n;
printf("1-企划部,2-财务部,3-人力资源部,4-市场部\n");
printf("请输入:");
scanf("%d",&n);
printf("你输入的是:");
switch(n)
{
case 1:
printf("企划部\n");
break;
case 2:
printf("财务部\n");
break;
case 3:
printf("人力资源部\n");
break;
case 4:
printf("市场部\n");
break;
}
}
Fortran的值为102
basic,assembly,ada,COBOL,Fortran分别是什么意思,不重要。C语言枚举型,系统只把它们作为用户自定义变量处理。没有特殊含义。
在定义枚举型变量ada的时候给它赋值100,那么COBOL就是101,Fortran102。
以上就是关于C语言简单枚举类型全部的内容,包括:C语言简单枚举类型、c++/c语言 枚举所有组合并输出、c++//如何实现下面c语言的枚举等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)