一、选择题(每题2分,共 50 分)
C语言中,运算对象必须是整型数的运算符是   A      。
 A、%    B、/        C、%和/     D、*
若有关系x≥y≥z,应使用    A     C语言表达式。
 A、(x>=y)&&(y>=z)   B、(x>=y)AND(y>=z)  C、(x>=y>=z)   D、(x>=y)&(y>=z)
下面程序的输出是   C                                                     main(  )                                                        {   int x=10,y=3;                                                               printf(“%d\n”,y=x/y);
 }
A、0 B、1 C、3 D、不确定的值
若float x ;x = 10/4 ; x的值是   B       。
 A、2.5         B、 2.0        C、 3         D、  2
设有以下语句:int a=3,b=6,c; c=a^b<<2; 则c的二进制值是   D    。
 A、00011011   B、00010100    C、00011100    D、00011000
在位运算中,某操作数 右移3位,其结果相当于   D                                            A、操作数乘以6   B、操作数除以6  C、操作数乘以8   D、操作数除以8
 表达式 !x 等价于     A        。
 A、x==0       B、x==1         C、x != 0       D、x != 1
下列语句定义pf为指向float类型变量f的指针,   B    是正确的。
 float f, *pf=f; B、float f, *pf=&f; C、float *pf=&f, f; D、float f, pf=f;
 执行下列程序段后,变量a,b,c的值分别是   D    。
      int x=10,y=9;
int a,b,c;
a=(--x==y++)?--x:++y;
b=x++;
c=y;
A、a=9,b=9,c=9 B、a=9,b=10,c=9 C、a=1,b=11,c=10 D、a=8,b=8,c=10
整型变量x和y的值相等,且为非0值,则以下选项中,结果为0的表达式是    D      。
 A、x || y   B、x | y   C、x & y    D、x ^ y
对两个数组a和b进行如下初始化
   char a[]=“ABCDEF”;   char b[]={ ‘A’,’B’,’C’,’D’,’E’,’F’};
则以下叙述正确的是 D 。
A、a和b数组完全相同 B、a和b长度相同
C、a和b中都存放字符串 D、a数组比b数组长度长
设变量定义为“int x, *p=&x;”,则&*p相当于   C     。
 A、p          B、*p           C、x         D、*&x
若已定义 char s[10]; 则在下面表达式中不表示s[1]的地址的是    B      。
 A、s+1     B、 s++      C、&s[0]+1      D、  &s[1]
以下程序的执行结果为      D  。
   #inlcude <stdio.h> 
#define N 2
#define M N+1
#define NUM (M+1)*M/2
main()
{pirntf("%d",NUM);} A、5 B、6 C、8 D、9
以下程序的输出结果是      A     。
 #define M(x,y,z) x*y+z
main()
{ int a=1,b=2, c=3;
printf("%d\n", M(a+b,b+c, c+a)); } A、19 B、17 C、15 D、12
int a[5][4], *p=a[0];,则*(p+2*4+3)等于      D     。
 A、a[2][0]    B、a[2][1]          C、a[2][2]   D、a[2][3]
int a[5][4], (*p)[4]=a;,数组a的首地址为100,*(p+2)+3等于   D        。
 A、116    B、118            C、144    D、122
int a[]={1,3,5,7,9},*p=a;,则值为5的表达式是     B    。
 A、p+=2, *p++   B、p+=2, *++p     C、p+=2, (*p)++  D、a+=2, *a
已知:char s[4] = "cba"; char *p; 执行语句序列p = s;printf("%c\n",*p+1);后,其输出为     D      。
 A、字符’c’   B、字符’b’    C、字符’a’ D、字符’d’
已有定义 int k=2; int *ptr1, *ptr2, 且ptr1和ptr2均已指向变量k , 下面不能执行的赋值语句是     A     
  A、k=*ptr1+*ptr2;        B、ptr2=k;
C、ptr1=ptr2; D、k=*ptr1*(*ptr2);
若有定义int i=2,a[10],*p=&a[i];则与*p++ 等价的是  A         。
 A、a[i++]   B、a[i]++   C、a[i]   D、a[++i]
以下对二维数组a的正确说明是   D        。
 A、 int a[ ][3]={ 0 };            B、int a[3][ ]={ {1},{2},{3} };
C、 int a[1][3]={ 1,2,3,4 }; D、int a[2][3]={ {1,2},{3,4},{5,6} };
以下程序的输出结果是     C      。
 void main()
{ int a=5,*p1,**p2;
p1=&a,p2=&p1;
(*p1)++;
printf("%d\n",**p2);
}
A、5 B、4 C、6 D、不确定
设有定义“int a=3,b,*p=&a;”,则下列语句中使b不为3的语句是    B       。
  A、b=*&a;   B、b=*a;   C、b=a;   D、b=*p;
int main(int argc, char *argv[])
 {
int i, n = 0;
for (i=1; i<argc; i++) { n = 10*n + *argv[i] – ‘0’; }
printf(“%d\n”, n);
}
./aout 12 345 678
输出结果为____A____。
A、123 B、136 C、678 D、58
1.冒泡排序(要求:从终端获取十个数,升序排序);
#include <stdio.h>
#define N 10
int main(int argc, const char *argv[])
{
     int i=0, j=0;
int arr[N] = {0};
for(i=0; i<N; i++)
    {
         scanf("%d",&arr[i]);
}
for(i=0; i<N-1; i++)
    {
         for(j=0; j<N-1-i; j++)
        {
             if(arr[j]>arr[j+1])
            {
                 arr[j] = arr[j]^arr[j+1];
arr[j+1] = arr[j]^arr[j+1];
arr[j] = arr[j]^arr[j+1];
}
}
}
for(i=0; i<N; i++)
    {
         printf("%d ",arr[i]);
}
putchar(10);
return 0;
}
编写程序将两个数组完成归并,并存入数组c中JIANG
#include<stdio.h>
 #include<string.h>
 char *mystrcat(char *dest, char *src);
 int main(int argc, const char *argv[])
 {
     char arr[50]="0";
     char brr[50]="0";
     char *pa=arr;
     char *pb=brr;
     printf("输入第一组数组:");
     gets(arr);
     printf("输入第二组数组:");
     gets(brr);
     mystrcat(pa,pb);
     printf("%s\n",pa);
     return 0;
 }
  
 char *mystrcat(char *dest,char *src)
 {
     char *ptr=dest;
     char *str=src;
     int i=0;
     int len1=strlen(ptr);
     int len2=strlen(str);
     for(i=0;i<len2;i++)
     {
         *(ptr+len1+i)=*(str+i);
     }
     return ptr;
 }
降序
include <stdio.h>
  
 #include <string.h>
  
 int main(int argc, const char *argv[])
  
 {
  
        int a[10];
  
        int i,j;
  
        int index,temp;
  
        printf("请输入10个整数:");
  
        for(i=0;i<10;i++)
  
        {
  
               scanf("%d",&a[i]);
  
        }
  
        for(i=0;i<10;i++)
  
        {
  
               index=i;
  
               for(j=i+1;j<10;j++)
  
               {
  
                      if(a[j]>a[index])
  
                      {
  
                             index=j;
  
                      }
  
               }
  
               temp=a[i];
  
               a[i]=a[index];
  
               a[index]=temp;
  
        }
  
        printf("排列后顺序为:");
  
        for(i=0;i<10;i++)
  
        {
  
               printf("%d ",a[i]);
  
        }
  
        printf("\n");
  
        return 0;
  
 }