C语言问答题2
1、程序的局部變量存在于(堆棧)中,全局變量存在于(靜態(tài)區(qū) )中,動(dòng)態(tài)申請數(shù)據(jù)存在于( 堆)中。
2、設(shè)有以下說明和定義:
typedef union
{
long i;
int k[5];
?char c;
} DATE;
struct data
?{
???int cat;
???DATE cow;
double dog;
} too;
DATE max;
則語句 printf("%d",sizeof(struct data)+sizeof(max));的執(zhí)行結(jié)果是:___52____
考點(diǎn):區(qū)別struct與union.(一般假定在32位機(jī)器上)
答:DATE是一個(gè)union, 變量公用空間. 里面最大的變量類型是int[5], 占用20個(gè)字節(jié). 所以它的大小是20. data是一個(gè)struct, 每個(gè)變量分開占用空間. 依次為int4 + DATE20 + double8 = 32. 所以結(jié)果是 20 + 32 = 52. 當(dāng)然...在某些16位編輯器下, int可能是2字節(jié),那么結(jié)果是 int2 + DATE10 + double8 = 20
3、隊(duì)列和棧有什么區(qū)別?
? 隊(duì)列先進(jìn)先出,棧后進(jìn)先出
4、寫出下列代碼的輸出內(nèi)容
#include?
int inc(int a)
?{?return(++a);?}
?int multi(int*a,int*b,int*c)
?{ return(*c=*a**b);?}
typedef int(FUNC1)(int in);
?typedef int(FUNC2) (int*,int*,int*);
void show(FUNC2 fun,int arg1, int*arg2)
{
??FUNC1 p=&inc;
int temp =p(arg1);
fun(&temp,&arg1, arg2);
printf("%dn",*arg2);
?}
?main()
?{
int a; ?????? //局部變量a為0;
show(multi,10,&a);
?return 0;
}
答:110
5、請找出下面代碼中的所有錯(cuò)誤?(題目不錯(cuò),值得一看)
說明:以下代碼是把一個(gè)字符串倒序,如“abcd”倒序后變?yōu)椤癲cba”
#include"string.h"
main()
{
char*src="hello,world";
char* dest=NULL;
int len=strlen(src);
dest=(char*)malloc(len); ???
char* d=dest;
char* s=src[len]; ?? ??????
while(len--!=0)
d++=s--; ???????
printf("%s",dest);
return 0;
}
答:
方法1:一共有4個(gè)錯(cuò)誤;
int main()
{
char* src = "hello,world";
int len = strlen(src);
char* dest = (char*)malloc(len+1);//要為分配一個(gè)空間 char* d = dest;
char* s = &src[len-1];??????????//指向最后一個(gè)字符
while( len-- != 0 )
*d++=*s--;
*d = 0;?????????? //尾部要加’\0’
printf("%sn",dest);
free(dest);??????? //?使用完,應(yīng)當(dāng)釋放空間,以免造成內(nèi)存匯泄露
dest = NULL; //防止產(chǎn)生野指針
return 0;
}
方法2: (方法一需要額外的存儲(chǔ)空間,效率不高.) 不錯(cuò)的想法
#include
#include
main()
{
char str[]="hello,world";
int len=strlen(str);
char t;
for(int i=0; i<len 2;="" i++)<="" font="" style="word-wrap: break-word;">
{
t=str[i];
str[i]=str[len-i-1];?//小心一點(diǎn)
str[len-i-1]=t;
}
printf("%s",str);
return 0;
}
總結(jié)