学历改变命运
24小时客服:4008135555/010-82335555
当前位置:首页 > 笔记串讲 > 自考“高级语言程序设计”习题答案详解(20

自考“高级语言程序设计”习题答案详解(20)

2007年09月04日    来源:   字体:   打印

  2.编程序,输入10个整数存入一维数组,再按逆序重新存放后再输出。

  「解」将数组的元素逆序重新存放,就是将数组的首尾对应元素两两交换。简单地可用两个游标变量i和j,i是前端元素的下标,j是后端元素的下标,交换以这两个变量值为下标的数组元素。开始时,i的值为0,j的值为末元素的下标。每次交换后,i增1,j减1.继续交换的

  条件是i<J.程序如下:

  # include

  main()

  { int a[10], i,j,t,n=10;

  printf(“Enter %d numbers! \n”, n);

  for(i=0;i<N;I++)

  scanf(“%d”,&a );

  for(i=0,j=n-1;i<J;I++,J——) {

  t= a; a=a[j] ;a[j] =t;

  }

  for(i=0; i<N; I++)

  printf(“%d\t”, a);

  printf(“\n”);

  }

  3.编程序,输入两个字符串(<40个字符) ,连接后输出(不准用系统函数) .

  「解」将字符串s2连接到字符串s1的计算过程可分两个步骤完成。首先找到字符串s1的末尾,然后参照字符串s2,将字符串s2的全部有效字符逐一复制到字符串s1,更后在字符串s1的末尾接上字符率结束标记符。完整程序如下:

  # include

  # define N 40

  main()

  { char s1[N] ,s2[N];

  int i,j;

  printf(“Enter stringl!\n”);

  scanf(“%s”,s1);

  printf(“Enter string2! \n”);

  scanf(“%s”, s2);

  for(i=0; sl!=‘\0’ ; i++) ;

  for(j=0;s2[j]!=‘\0’ ;i++,j++)

  so=s[j] ;

  s1=‘\0’

  printf(“sl=%s\n” ,sl);

  }

关闭