C语言枚举序列问题

Posted

tags:

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

程序的一部分:
while(1)

lambda=...;
然后执行程序的其他部分(关于lambda);
当lambda满足某些条件时推出循环。


要求 lambda (while 循环一次取一个新的lambda值)依次取下面的值:
lambda, (a[i] 系数之和为 0)
lambda-a[1], lambda-a[2], ..., lambda-a[k-1], (a[i] 系数之和为 -1)
lambda-2a[1], lambda-a[1]-a[2], lambda-a[1]-a[3], ..., lambda-a[1]-a[k-1], lambda-2a[2], lambda-a[2]-a[3], ..., lambda-a[2]-a[k-1], ..., lambda-a[k-2]-a[k-1], lambda-2a[k-1], (a[i] 系数之和为 -2)
lamdba-3a[1], ... (a[i] 系数之和为 -3)
...
能不能有什么好的方法实现上面的想法?谢谢了。

如果k固定,比如k=2,可以用两个循环,代码大概如下
int c[2]; //k=2
int n;

// n, a[i] 已经知道

while(1)


for(c[0]=0; c[0]<n; c[0]++)


for(c[1]=0; c[1]<n-c[0]; c[1]++) //c[0] + c[1] = n

for(i=0; i<2; i++)

lambda=lambda-c[i]*a[i]; //计算 lambda-c[0]*a[0]-...-c[k-1]*a[k-1]


程序其他部分

若lambda满足某些条件,退出循环;



若lambda满足某些条件,退出循环;



若lambda满足某些条件,退出循环;



如果k知道,就可以用k个循环。但是现在k不知道,不知道用几个循环,有没有解决办法?
谢谢

参考技术A unknown number of loops

典型的recursion问题,需要定义递归函数来做。
参考技术B 40元买苹果,西瓜,梨共100个,3种都要. 苹果0.4元,西瓜4元,梨0.2元.编程:求可以买多少个并输出全部购买方案问题补充:为什么我运行后再ALT F5什么都 参考技术C ?本回答被提问者采纳

C语言枚举类型,知道这些你就会了

参考技术A

在实际编程中,有些数据的取值往往是有限的,只能是非常少量的整数,并且最好为每个值都取一个名字,以方便在后续代码中使用,比如一个星期只有七天,一年只有十二个月,一个班每周有六门课程等。
以每周七天为例,我们可以使用 #define 命令来给每天指定一个名字:

#define 命令虽然能解决问题,但也带来了不小的副作用,导致宏名过多,代码松散,看起来总有点不舒服。C语言提供了一种 枚举(Enum)类型 ,能够列出所有可能的取值,并给它们取一个名字。

enum 是一个新的关键字,专门用来定义枚举类型,这也是它在C语言中的唯一用途; typeName 是枚举类型的名字; valueName1, valueName2, valueName3, ...... 是每个值对应的名字的列表。注意最后的 ; 不能少。

例如,列出一个星期有几天:

可以看到,我们仅仅给出了名字,却没有给出名字对应的值,这是因为枚举值默认从 0 开始,往后逐个加 1(递增);也就是说,week 中的 Mon、Tues ...... Sun 对应的值分别为 0、1 ...... 6。

我们也可以给每个名字都指定一个值:

更为简单的方法是只给第一个名字指定值:

这样枚举值就从 1 开始递增,跟上面的写法是等效的。
枚举是一种类型,通过它可以定义枚举变量:

也可以在定义枚举类型的同时定义变量:

有了枚举变量,就可以把列表中的值赋给它:

或者:

Mon、Tues、Wed 这些名字都被替换成了对应的数字。这意味着,Mon、Tues、Wed 等都不是变量,它们不占用数据区(常量区、全局数据区、栈区和堆区)的内存,而是直接被编译到命令里面,放到代码区,所以不能用 & 取得它们的地址。这就是枚举的本质。

枚举类型变量需要存放的是一个整数,它的长度和 int 相同。

以上是关于C语言枚举序列问题的主要内容,如果未能解决你的问题,请参考以下文章

求教C语言枚举类型的问题

C语言枚举问题 猴子分桃

C语言枚举类型,知道这些你就会了

C语言的枚举类型知识

C语言简单枚举类型

C语言中关于枚举类型