杭州快越科技
填空
1、char型数据在微机中储存值为0xc0,则printf以%d打印值为 -64
2、char a=203;int b =a;int c = a&0xff ;b=-53 ;c=203 ;
3、linux下32位系统,char str = “hello”;char *p = str; int n = 10;
sizeof(str)= 6 ;sizeof (p)= 4 ;sizeof (n)= 4 ;
4、int a=1,b=2,c=3,d=4,m=2,n=2;执行(m=a>b)&&(n=c>d)后,n=2
5、#define M(x,y,z) x*y+z,当a=1,b=2,c=3则M(a+b,b+c,c+a)=19
单选
1、若有说明 int (*p)[3],,以下叙述正确的是( D)
A.P是指针数组
B.B.(*p)[3]和*p[3]等价
C.P是指向以为数组中任何一个元素的指针
D.P是指向含有3个整型元素的以为数组的指针
2、设数组a[5] = {10,20,30,40,50};已知指针P指向a[1];则表达式*++p的值是( B )
A.31 B. 30 C. 21 D. 20
3、有以下程序段,执行后,mul的值为( C )
int a[ ] = {1,3,5,7,9};
int mul, *data , x;
mul = 1;
data = &a[1];
for(x=0; x<3; x++){
mul *= *(data+x);
}
printf(“%d\n”, mul);
A.945 B.315 C.105 D.15
4、以下语句不能正确赋值的是( D )
A. char *s=" China" ;
B. char s3[20]=" China" ;
C. char s2[]={'C', 'h', 'i', 'n', 'a'};
D. char s1[10]; s1=" China" ;
5、设有如下结构定义: struct student {int num; char name[20]; char sex; int age; char addr[30]; }stud; 若用printf( "%s\n" ,...)访问该结构中name值的正确方法是( D )
A. stud- > name
B. &stud.name
C. stud.&name
D. stud.name
6、有以下程序段x=7执行后的值为( B )
int fun(int x) {
int p; if(x= =0 || x==1)
return(3);
p=x -fun(x- 2);
return p;
}
B. 0 B. 2 C.5 D.6
7、假语句while(!E)中的表达式E等价于(A)
A. E ==1 B. E != 0 C. E !=1 D. E==0
8、有以下程序端,int k=0; while(k=1) k++; 则while循环执行的次数是( D )
A. 一次也不执行
B. 执行1次
C.有语法错,不能执行
D.无数次
9、以下程序运行后,输出结果是( A )
main( )
{
char ch[2][5] = {“693”, “825”}; *p[2];
int i, j, s = 0;
for(i=0; i<2; i++) p[i] = ch[i]
for(i=0; i<2; i++)
for(j=0; p[i][j]>=’0’ && p[i][j] <=’9’; j+=2)
s=10*s+p[i][j]-‘0’;
printf(“%d\n”, s);
}
A. 6385 B.33 C.693825 D.22
10、以下程序while循环的循环次数是( A )
main(){
int i=0;
while(i<10)
{
if(i<1)
continue,
if(i-=5) break;
i+ +:
}
}
A. 死循环,不能确定次数
B. 6
C,10
D. 1
11、以下对妆举类型名的定义中正确的是(C )
A. enum a {"one”, "two', "thee”};
B. enum a={"one', "two', "thee”};
C. enum a {one=9, two=-1, three};
D.enum a={one, two, three};
12、以下程序运行后,输出结果是(D ) int x=3, do{ print(%3d"; x -=2; } whlie(!(--x));
A. 死循环
B. 12
C. 30
D. 1
13、以下程序运行后,输出的结果是( C )
main()
{
Char *s = “12134211”; int v[4] = {0,0,0,0}, k, i;
for(k=0; s[k]; k++){
switch(s[k]){
case ‘1’: i=0;
case ‘2’: i=1;
case ‘3’: i=2;
case ‘4’; i=3;
}
v[i]++;
}
for (k=0; k<4; k++) printf(“%d”, v[k]);
}
A. 4 6 7 8
B. 8 8 8 8
C. 0 0 0 8
D. 4 2 1 1
14、假定有以下变量定义;int k=7, x=12;则能使值为3的表达式为( B )
A. (x%=k)-(k%=5)
B. x%=k-k%5
C. x%=(k-k%5)
D. x%=(k%=5)
15、设有如下结构定义:struct student {char name[20]; char sex; int age; char addr[30];} studA, stud B; 若用把studA拷贝给studB正确的方法是( D )
A. strcpy(studB, studA);
B. strcpy(studB, studA, sizeof(studA));
C. memcpy(studB, studA, sizeof(studA));
D. memcpy(&studB, &studA, sizeof(studA));
16、想要对一个文件文件的尾部追加写入,应当在fopen语句中使用的文件操作方式指示符号为( C )
A. r B. wb C. a D.w
17、为了比较两个字符串s1和s2 是否相等,应当使用( D )
A. if(s1 == s2)
B. if(s1 = s2)
C. if(strcmp(&s1, &s2) == 0)
D. if(strcmp(s1, s2) == 0)
18、有以下程序,程序运行后的输出结果是( C )
#include
#include
main()
{
char* p = “abcde\0fghijk\0”;
printf(“%d\n”, strlen(p));
}
A.15 B. 6 C. 5 D.12
改错题
如下程序中用于输出 “welcome home”。请指出其中的错误
void Test(void)
{
char pcArray[12]; -------------------------------char pcArray[13];
strcpy(pcArray, “welcome home”);
printf(“%s!”, pcArray);
return;
}
编程题
1、宏定义,比较返回大的
#define max(a,b) (((a)>(b)) ? (a) : (b))
2、<stdio.h>与”stdio.h”的区别
(1)<stdio.h>是直接到标准库目录进行寻找
(2)“stdio.h”是到指定的目录查找,后到标准库目录进行寻找
3、数组里数,从小到大输出
#include <stdio.h>
void swap(int *a, int *b)
{
*a = *a^*b;
*b = *a^*b;
*a = *a^*b;
}
int main(int argc, char const *argv[])
{
int a[100] = {0};
int n = 0;
printf("请输入数组个数:");
scanf("%d", &n);
for(int i = 0; i < n; i++)
{
scanf("%d",&a[i]);
}
int k = 0;
for(int i = 0; i < n-1; i++)
{
k = i;
for(int j = i+1; j < n; j++)
{
if(a[k] > a[j])
k = j;
}
if(k != i)
swap(&a[k], &a[i]);
}
for(int i = 0; i < n; i++)
{
printf("%d ", a[i]);
}
printf("\n");
return 0;
}
4、仿写strcpy,有strcpy,返回char*的意义,没学指针可以暂时不返回
char *my_strcpy(char *dest, const char *src)
{
char *tmp = dest;
while(*dest++ = *src++)
{
;
}
return tmp;
}
生活题(简答)
有层楼共100层,有两个完全一样的弹珠,都有相同的坚韧度,如何确定弹珠在哪一层会承受不住而崩碎
一个球均匀分段的扔,比如 分为10层一次地扔,如果在40层破,我从20层扔到40层。这样大大提高了效率。第一次扔k层 ,则次数time=1,第二次,如果破了,要试从1到k-1层,此时需要sumTime=time+k-1=k 次;
如果没破,还要从2k层扔,则次数为time=2;如果破了,还需要扔k+1到2k-1层,再加上前面扔的两次time=2, 即 sumTime=time+k-2=k。还是k 次;
注意每多扔一次 少测试一层。次数却多一次。且实际只要能测到n-1层就够了
那么假设扔k次能知道临界点,共有n层楼.
以此类推如果满足 k+(k-1)+(k-2)+(k-3)+(k-4)+....+(k-k+1) >=n-1 。
可以化简得到:k(k-1)>=2(n-1)
这里,n=100 所以 解得k=14。
卡尔电气
- C语言基础考题(40)
选择题 20分每题2分
1、已知字母A的ASCII码为十进制数值65,且S为字符型,则执行语句S='A'+'6'-'3';后S中的值为 (A )
A.'D' B.68 C.不确定的值 D.'C'
2、若有定义语句:int a=12;,则执行语句:a+= a-= a*a;后,a的值是 ( D)
A.264 B.552 C.144 D.-264
3、设有以下程序段int y;y=rand() % 30+1;则变量 y 的取值范围是 ( C)
A.1<y<30 B.0≤y≤30 C.0<y≤30 D.1<y≤30
4、已知int x=10,y=20,z=30;以下语句执行后x,y,z的值是 ( B)
if (x>y) z=x; x=y; y=z;
A.x=10,y=20,z=30 B.x=20,y=30,z=30 C.x=20,y=30,z=10 D.x=20,y=30,z=20
5.请读程序:
#define ADD(x) x+x
main()
{
int m=1,n=2,k=3;
int sum=ADD(m+n)*k;
printf("sum=%d",sum);
}
输出结果是 (C )
A.sum=9 B.sum=10 C.sum=12 D.sum=18
6.以下程序有错误,错误原因是(A )
main()
{
int *p,I;char *q,ch;
p=&I;
q=&ch;
*p=40;
*p=*q;
...
}
A.p和q的类型不一致,不能执行*p=*q;语句
B.p中存放的是地址值,因此不能执行*p=40;语句
C.q没有指向具体的存储单元,所以*q没有实际意义
D.q虽然指向了具体的存储单元,但该单元中没有确定值,多以不能执行*p=*q;语句
7.当顺利执行了文件关闭操作时,fclose函数的返回值是 ( )
A.-1 B.TRUE C.0 D.1
8.假设变量a,b均为整形,表达式(a=5,b=2,a>b?a++:b++.a+b)的值是 ( B)
A.7 B.8 C.9 D.2
9.设有如下程序段,下面描述中正确的是 (C )
int k=10;while(k=0)k=k-1;
A.循环执行一次 B.循环是无限循环 C.循环体语句一次也不执行 D.循环体语句执行一次
10.设有以下程序段,则值为6的表达式是 (C )
struct st {int n;struct st *next};
static struct st a[3]={5,&a[1],7,&a[2],9,&a[0]},*p;p = &a[0];
A.p++->n B.++p->n C.p->n++ D.(*p).n++
编程题20分每题10分
1.编写函数求1~100中奇数的平方与偶数的立方的和
int add()
{
int sum1 = 0, sum2 = 0;
for(int i = 1; i < 101; i++)
{
if(0 == i % 2)
{
sum2 += i*i*i;
}
else
{
sum1 += i*i;
}
}
return sum1+sum2;
}
2、采用动态分配内存的方式,现将1k的缓冲区填充从512到1536的数据,并将其以32字节为一行打印输出出来。