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不知道,不知道用几个循环,有没有解决办法?
谢谢
典型的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语言枚举序列问题的主要内容,如果未能解决你的问题,请参考以下文章