1. 写出下列程序输出结果 (5)
#define add(a+b) (a+b)+(a+b) // (6+4)+(6+4)*7 = 80
x=6;y=4;z=7;
d=add(x+y)*z;
printf("d=%d\n",d);
2. (5)
有四个外表看起来没有分别的小球,它们的重量可能各有不同。取一个天平将甲、乙放一组,丙、丁为另一组分别放在天平的两边,天平是基本平衡的。将乙和丁对调一下,甲、丁一边明显地要比乙、丙一边重很多。可奇怪的是我们将天平的一边放上甲、丙,而另一边刚放上乙,还没有来得及放上丁时,天平就压向了乙一边。则四个球由重到轻的顺序是( A)
A.丁、乙、甲、丙
B.丁、乙、丙、甲
C.乙、丙、丁、甲
D.乙、甲、丁、丙
E.乙、丁、甲、丙
3. 实现函数 int HostOrder(); 返回当前的主机字节序。如果是大端返回1,如果是小端返回0 (10)
Int HostOrder()
{
Union var{
Char cVar ;
Int iVar ;
} ;
Union var var ;
Bzero(&var,sizeof(var));
Var.iVar = 0x01;
If(cVar == 1)
{
Return 0;
}else {
Return 1;
}
}
4. 解释gcc下列选项的含义 -Ι -L -D -c (10)
-I : 头文件
-L : 库路径
-D: 预定编译
-c: 编译
5. 下列函数实现累加(1…base)求和,判断是否有错误?如果有如何改正 (5)
unsigned int sum(unsigned int base)
{
static unsigned int sum=0;
unsigned int index;
for (index=1;index<=base;index++) sum+=index;
return sum;
}
// static 去掉, int --> long
6. 实现函数char *fun(char *str1, char *str2); 从字符串str1中返回字串str2的地址,若str2不存在,返回NULL。(15)
char *substr(char *str1, char *str2)
{
int i=0,j;
for(i=0;i<strlen(str1)-strlen(str2)+1;i++)
{
for(j=0;j<strlen(str2)&&str1[i+j]==str2[j];j++){}
if(j>=strlen(str2)) return &str1[i];
}
return NULL;
}
7. 实现下列函数 unsigned int sum(unsigned int val); 将val中每个字节的值取出累加后返回 (10)
unsigned int sum(unsigned int val)
{
Unsigned char *p = &var ;
Unsigned sum = 0;
For(int i = 0;i< sizeof(var)/sizeof(*p) ; i ++)
{
Sum + = *p++;
}
Return sum;
}
8. 编写程序统计一个文本文件中有多少个单词 (20)
int readData(char filename[]) //此函数计算英文单词个数
{
FILE* fp;
char ch;
char flag = -1;
int num=0;
if((fp = fopen(filename,"r")) == NULL)
{
printf("%s open failure",filename);
exit(EXIT_FAILURE);
}
printf("%s open sucessfully!~\n",filename);
while(!feof(fp))
{
ch = fgetc(fp);
//(ch < 0x80) 排除汉字的干扰
if((ch >= 'A' && ch <= 'Z') || (ch >= 'a' && ch <= 'z') || (ch >= '0' && ch <= '9'))
flag = 0;
else if(flag == 0 && (ch != '-' && ch != '/'&& ch != '\''))
{
num++;
flag = 1;
}
}
fclose(fp);
return num;
}
9. (20)编写一个程序实现类似printf的功能:以第一个参数为格式,输出后续参数的内容。格式符包括%c、%d和%s。例如 ./a.out “i = %s, c = %c” 10 a 程序执行时打印
i = 10, c = a
#include <stdio.h>
#include <stdlib.h>
int main(int argc, char *argv[])
{
int i ;
int count = 0;
char *para[128];
char *p = NULL,*q;
if(argc < 2)
{
printf("please input valid parameter ...\n");
return -1;
}
printf("argc = %d\n",argc);
for(i = 0; i <= argc -2 ; i ++)
{
para[i] = argv[i+1];
}
p = para[0];
while(*p != '\0')
{
if(*p == '%')
{
count ++;
}
p++;
}
if(count != (argc -2) )
{
printf("please input valid parameter ...\n");
return -1;
}
count = 1;
p = para[0];
while(*p != '\0')
{
if(*p != '%' )
{
putchar(*p);
}
else
{
q = para[count];
if(*(p+1) == 'd')
{
while(*q != '\0')
{
putchar(*q);
q ++;
}
}else if(*(p+1) == 'c')
{
putchar(*q);
}else if(*(p + 1) == 's')
{
while(*q != '\0')
{
putchar(*q);
q ++;
}
}
count ++;
p ++;
}
p ++;
}
putchar('\n');
return 0;
}