1. c语言中为什么不能定义位段数组
你希望的位段数组是什么样的?C语言变量定义本质上就是给要存储的数据分配好相应的内存空间,最小单位是一个字节(用结构联合体特殊技巧可以访问到byte位)。关键在于你怎么去利用。
2. c语言 定义一个全1数组
定义完用循环来赋值
int a[100];
int i;
for(i=0;i<100;i++)
a[i]=1;
3. C语言 定义一个一维数组,并给数组赋值
#include <stdio.h>
int main()
{
int a[10];
int i,s=0,max=0;
for(i=0;i<10;i++)
{
scanf("%d", &a[i]);
if(a[i]>max)
max=a[i];
s+=a[i];
}
for(i=0;i<10;i++)
printf("%d ", a[i]);
printf(" ");
for(i--;i>=0;i--)
printf("%d ", a[i]);
printf(" ");
printf("ave=%f, max=%d ", ((float)s)/10, max);
}
4. c语言。数组定义
可以省略。但不能全部省略。你全部省略了,放入20个数。谁知道你是2行10列还是4行5列还是10行2列等等。。。
5. c语言定义一个不知道个数的一维数组
这个是可以的,不知你们是否学过动态内存开辟啊!即可以定义一个指针通过malloc 或者 calloc 来通过自己的输入来确定类存大小,如果还没学,建议按顺序后面会学到的啊!
6. c语言中数组的定义和使用是什么
动态数组是指在声明时没有确定数组大小的数组,即忽略方括号中的下标。使用时,可随时用ReDim语句(C语言中用malloc语句)重新指出数组的大小。
动态数组,是相对于静态数组而言。静态数组的长度是预先定义好的,在整个程序中,一旦给定大小后就无法改变。
而动态数组则不然,它可以随程序需要而重新指定大小。动态数组的内存空间是从堆(heap)上分配(即动态分配)的。是通过执行代码而为其分配存储空间。当程序执行到这些语句时,才为其分配。程序员自己负责释放内存。使用动态数组的优点是可以根据用户需要,有效利用存储空间。
动态数组与静态数组的对比:
对于静态数组,其创建非常方便,使用完也无需释放,要引用也简单,但是创建后无法改变其大小是其致命弱点。
对于动态数组,其创建麻烦,使用完必须由程序员自己释放,否则严重会引起内存泄露。但其使用非常灵活,能根据程序需要动态分配大小。
7. C语言中如何定义数组
数组定义的三种方式
1、第一种
int []a = newint[5];
a[0] = 10;
2、第二种
int []c = newint[]{1,2,3};
3、第三种
int []i ={1,2,3,4};
4、错误的写法
int []i1 = [1,2,3,4];
System.out.println(Arrays.toString(c));
5、总之,具体的元素不能被【】包裹。【】包裹的应该是数组的数量。
(7)c语言位数组的定义扩展阅读
数组的注意事项:
1、 数组中每个元素的数据类型必须相同,对于inta[4];,每个元素都必须为 int。
2、 数组长度 length最好是整数或者常量表达式,
3、 访问数组元素时,下标的取值范围为 0 ≤ index < length,
参考资料
网络-数组
8. C语言数组的定义问题
你先定义一个全局变量N,你就可以N=你要的数
定义数组str[N]
用float的吧
你试试能不能
9. C语言编程中数组的定义
这种题目一般不希望设计内存管理。所以一般都是进可能给一个比较大的数组。
例如
a[10];
表示位数不会超过十,你输入的时候需要个索引记录a[]数组有效的位数。
使用的时候,只使用有效位数。
肯定会有一段内存不用的。或多或少。这就是数组存储动态数据特点。
如果内存管理的话,你设计个增量比如5.
一旦索引告诉你10个位置用完了,地方不够,你在动态申请
15个位置,把原来的复制到新的内存空间。
这就是数组内存管理的方法,但是一般程序不要求这样,因为你要作的是实现算法思想,而不是去想这些内存管理的方面。
所以现在大多不需要程序员考虑内存管理。对实现算法而讲,注重的是实现的思想。
a[10]不行,你就设置你认为足够长的。比如a[100]
通常这种情况,你要考虑你输入的最大数字对应的位数,这种题目肯定是有上限的,不是任何数都可以。
我刚看你的程序了,10进制变16进制程序有误,你没有考虑余数10,11...
10对应A,11对应B..
这样的话,应该用char[]数组存储。
下面是程序
你输入15,会输出F
100,会输出64
#include <stdio.h>
#include <math.h>
void main()
{
int num;
printf("请输入一个十进制整数:");
scanf("%d",&num);
char a[100]; //这里的数组长度应当依据什么来定义
int i=0;
int yushu;
while(num>0)
{
yushu=num%16;
if(yushu<10)
a[i]=yushu+'0';
else
a[i]='A'+(yushu-10);
num=num/16;
i++;
}
i--;
printf("转化为十六进制的数为:");
for(;i>=0;i--)
{
printf("%c",a[i]);
}
printf("\n");
}