阅读以下说明和C程序代码,回答问题1至问题3,将答案填入答题纸的对应栏内。 【说明】 【程序1】是关于条件编译的一段程序示例; 【程序2】是一段switch语句应用示例。C语言要求switch之后圆括弧内的“表达式” 类型必须是整型或字符型

admin2017-11-27  56

问题 阅读以下说明和C程序代码,回答问题1至问题3,将答案填入答题纸的对应栏内。
【说明】
    【程序1】是关于条件编译的一段程序示例;
    【程序2】是一段switch语句应用示例。C语言要求switch之后圆括弧内的“表达式” 类型必须是整型或字符型。该程序代码中a与x的对应关系如表5-1所示。

    【程序3】是冒泡排序算法的实现。假设有N个数据存放在数组aa中,用冒泡排序将这N个数从小到大排序。首先,在aa[0]到aa[N-1]的范围内,依次比较两个相邻元素的值,若aa[j]>aa[j+1],则交换aa[j]与aa[j+1],j的值取0,1,2,…,N一2;经过这样一趟冒泡,就把这N个数中最大的数放到aa[N—1]中。接下来对aa[0]到aa[N一2]中的数再进行一趟冒泡,这样就将该范围内的最大值换到aa[N-2]中。依次进行下去,最多只要进行N-1趟冒泡,就可完成排序。如果在某趟冒泡过程中没有交换相邻的值,则说明排序已完成,可以提前结束处理。
【C程序代码l】
    #include
    #define_DEF_X
    main()
    {
       int x;
    #ifndef_DEF_X
       x=1;
    #else
       x=2;
    #endif
       printf(”x=%d\n”,  x);
   }
【C程序代码2】
    float a;
    int x;
    Scanf(”%d”,&a);
switch(  (int)a)
    {
      case 0:
      case 1:
      case 2:
        if(a>2)X=1;
        else  (1)  ;
        break;
    case 3:
       (2)
       break;
    case 4:
      (3)
      break;
    default:
       prinf(”a is error\r\n”);
    }
【C程序代码3】
    #include
    #define N 8
    main()
    {
      int I,j,aa[N],temp,swap;
      clrscr();
      for(i=0;i            scanf("%d”,(4));
    for(i=0;i    {
    swap=0;
    for(j=0;j<(5);j++)
    {
       if(aa[j]>aa[j+1])
       {
    swap=1;.
      temp=aa[j];
      aa[j]=aa[j+1];
      aa[j+1]=temp;
     }
  }
    if(  (6)  )  break;
    }
    for(i=0;  i        printf(”%d  ”,  aa);
    printf(”\n”);
    }
完成【C程序代码3】中的(4)~(6)空,将答案写到答题纸相应的位置。

选项

答案(4)&aa[i] (5)N-i-1 (6)!swap或swap=0

解析 本题为冒泡排序算法的一种程序实现,其算法的实现方法在【程序3】已经讲的很清楚。程序是对规模为8的一组数进行用冒泡排序从小到大排序,首先要求输入这8个数,存入数组aa中,使用“scanf("%d",&aa);”在冒泡排序算法开始执行后,用for循环语句来控制排序趟数和每一趟的结束位置,语句应为“for([j=0;j
转载请注明原文地址:https://kaotiyun.com/show/8QWZ777K
0

相关试题推荐
最新回复(0)