当前位置:首页 » 编程语言 » c语言数组存储方式
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

c语言数组存储方式

发布时间: 2022-02-25 01:25:01

A. c语言用数组存储大型数据的算法

/*
size_a,pa——指向数组a的有效末端
ma——a的最大容量,必须大于na

n=12——求n的阶
p——求阶乘时的当前乘数
*/
#include<stdio.h>
#define Ma 10000
int pa;/*指向数组a的有效末端*/
int p=2;
int memory_over=0;
union data
{ unsigned long int b;
struct
{unsigned l:16;
unsigned h:16;
}m;
}a[Ma];
/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
算法说明1:考虑到result比较长,我用a[Ma].b来存储n!的result,每一位a[pa].b能存储4位10进制数字。
因为我定义的数组是静态的,所以Ma应该足够大。
ps:其实只用定义一个unsigned long int b[Ma];就可以了(直接用b[pa]代替a[pa].b),但是我考虑到可能会访问每一结点b[pa]的高16位(a[pa].m.h)和低16位(a[pa].m.l),但是的我考虑是多余的!!不用像我这样定义这么复杂的共用体!!
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
unsigned int cashe;
unsigned int carry;

void main()
{
unsigned int n;/*求n的阶*/
void facto(unsigned int n);
printf("Input n:");
scanf("%u",&n);
/*=================开始求阶乘!=============*/
a[0].b=1;/*初始化*/
facto(n);
/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
算法说明2:上面这句直接调用facto(n)来求n!
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
/*========================以下是显示最后结果====================================*/
if(memory_over==0)
{printf("the result include %dNO:\n",pa+1);
printf("%u",a[pa--].m.l);
for(;pa>=0;pa--)
printf("%04u",a[pa].m.l);
printf("\n");
}
getch();
}

/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
算法说明2:求阶函数facto(n)说明:
这个函数会不断地调用multiple(),它的作用是每被调用一次就使得a[pa].b与阶数p相乘一次,直到乘完n为止!
{multiple();
p++;/*每一轮乘一个阶数p*/
}
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
void facto(unsigned int n)
{void multiple();
pa=0;
while(pa<Ma-1&&p<=n)/*容量限制*/
{multiple();
p++;/*每一轮乘一个阶数p*/
}
if(p<=n)
{printf("memory out!\n");memory_over=1;}/*如果当前的存储结果的数组a[Ma]不够用!应提高Ma*/

}

/*==============================================================================
算法说明3:乘法函数multiple()说明:负责a[pa].b与阶数p相乘。
a[pa].b有很多结点,a[0].b、a[1].b、a[2].b、a[3].b、a[4].b、。。。
当然是从低结点a[0].b开始不断与p相乘,产生的“进位”加到高位a[1].b,直到a[pa].b*p为止!

随着结果数值增大,pa个结点的a[].b可能容纳不下结果,所以如果a[pa].b与p相乘后还有“进位”carry,就扩大pa,并把carry放入到新增加的结点:
if(carry>0)
a[++pa].b=carry;
===================================================================================*/
void multiple()
{int i=0;
carry=0;
while(i<=pa)/*i指向当前处理的元素a[i],每一轮用一个位与阶数p相乘*/
{a[i].b=a[i].b*p+carry;/*计算结果,要考虑来自低位的进位*/
carry=a[i].b/10000;/*计算进位*/
a[i].b=a[i].b%10000;/*计算余数*/
i++;
}
if(carry>0)
a[++pa].b=carry;
}

B. c语言数组存储

你可知道char b[][100]={0};这是什么意思吗?当你不指定第二维的长度,初始化时又没明确指出其长度,那么编译器就会把上式变为:char b[1][100]={0};结果你只开辟了1组100个char的数组,你还以为能有10组,当然错误啦。如果明确包含10个字符串,请明确指定:char b[10][100]={0};

你这个弹错,意思就是你开辟的内存空间不够,导致strcpy函数运行时缓冲区溢出,这使得程序跳转到一个非法的区域,这个区域被操作系统标记为保护,于是触发“CPU常规保护异常”。

以下仅作谈资,骗分数用的^ ^。
我印象中,如果是“CPU常规保护异常”,可能意味着你这跳转到的地方是操作系统内核区。当CPU以用户权限等级(最低权限等级,你这个main函数执行时,printf函数执行前或执行后是就是这种状态)尝试跳转到/访问需要CPU最高特权等级的区域就会触发这类错误。

C. C语言中如何用数组存放数

把这个数转换为字符,以字符形式输出。
或者直接sprint(a,long num )
,然后printf("%s",a),

D. c语言数组存储形式是怎么根据的如

c语言中没有字符串的储存形式像
string
arr;是c++中才出现的,c语言中的字符串是储存在数组中的而且以'\0'为结束标志

E. C语言数组定义和存储。

不会,除非桟区溢出,另外你这种定义的方法是有危险的,照你这种思路,甚至都能找到c[100][3],
这个对编译器肯定是一种考验,支持楼上的说法,是编译器,我的观点是,虽然c语言相对java c#不安全,但我们应该尽量将它处理安全

F. C语言数据文件有几种存储方式每种存储形式各有什么特点

一、auto auto称为自动变量。 局部变量是指在函数内部说明的变量(有时也称为自动变量)。用关键字auto进7行说明, 当auto省略时, 所有的非全程变量都被认为是局部变量, 所以auto实际上从来不用。 局部变量在函数调用时自动产生, 但不会自动初始化, 随函数调用的结束, 这个变量也就自动消失了, 下次调用此函数时再自动产生, 还要再赋值, 退出时又自动消失。 二、static static称为静态变量。根据变量的类型可以分为静态局部变量和静态全程变量。 1. 静态局部变量 它与局部变量的区别在于: 在函数退出时, 这个变量始终存在, 但不能被其它、函数使用, 当再次进入该函数时, 将保存上次的结果。其它与局部变量一样。 2. 静态全程变量 Turbo C2.0允许将大型程序分成若干独立模块文件分别编译, 然后将所有模块的目标文件连接在一起, 从而提高编译速度, 同时也便于软件的管理和维护。静态全程变量就是指只在定义它的源文件中可见而在其它源文件中不可见的变量。它与全程变量的区别是: 全程变量可以再说明为外部变量(extern), 被其它源文件使用,而静态全程变量却不能再被说明为外部的, 即只能被所在的源文件使用。 三、extern extern称为外部变量。为了使变量除了在定义它的源文件中可以使用外, 还要被其它文件使用。因此, 必须将全程变量通知每一个程序模块文件, 此时可用extern来说明。 四、register register称为寄存器变量。它只能用于整型和字符型变量。定义符register说明的变量被Turbo C2.0存储在CPU的寄存器中, 而不是象普通的变量那样存储在内存中, 这样可以提高运算速度。但是Turbo C2.0只允许同时定义两个寄存器变量,一旦超过两个, 编译程序会自动地将超过限制数目的寄存器变量当作非寄存器变量来处理。因此, 寄存器变量常用在同一变量名频繁出现的地方。另外, 寄存器变量只适用于局部变量和函数的形式参数, 它属于auto型变量,因此, 不能用作全程变量。定义一个整型寄存器变量可写成: register int a;

G. C语言中数据(如字符型数据等)的存储形式是什么

C语言中的所有数据,都是以二进制方式存储的。
事实上,在计算机中,只有二进制的数据,其它的所有形式,字符,8进制,10进制,或者16进制,都是给人看的。

对于计算机来说,作为一个电子产品,能够识别的只有高低电平,开路闭路,所以实际上,在计算机中,无论是运算还是存储,都只是0和1的序列。

H. C语言中数据的存储方式是什么

动态存储方式和静态存储方式(按存储时间分配的)
static声明是静态的,其他是动态的
int f1(int a)
{
static int b = 0;
return (a+b);
}

int f2(int a)
{
int b = 0;;
return (a+b);
}

int main()
{
printf("%d",f1(0));//0
printf("%d",f1(0));//1
printf("%d",f2(0));//0
printf("%d",f2(0));//0
return 0;
}

I. c语言问题:c语言中二维数组在内存中怎样存储

严格意义上说不存在二维数组,只是数组里的每个元素是一个一维数组,而内存是一段连续的空间,根据你申请一个变量的顺序按地址从低到高排,所以二维数组不可能像一个矩阵那样在内存中排列,这就涉及到它是按行依次往下排,还是按列往下排,而在c++中是按行,既 int a[2][2]
a[0][0]
a[0][1]
a[1][0]
a[1][1]