亚洲精品中文字幕无乱码_久久亚洲精品无码AV大片_最新国产免费Av网址_国产精品3级片

計算機(jī)等級

下半年三級網(wǎng)絡(luò)技術(shù)上機(jī)題帶答案

時間:2024-09-16 23:43:11 計算機(jī)等級 我要投稿
  • 相關(guān)推薦

2016下半年三級網(wǎng)絡(luò)技術(shù)上機(jī)題(帶答案)

  2016年第二次計算機(jī)等級考試正在緊張備考中,為方便考生復(fù)習(xí)計算機(jī)三級網(wǎng)絡(luò)技術(shù)上機(jī)知識,yjbys小編特整理最新網(wǎng)絡(luò)技術(shù)上機(jī)模擬試題及答案解析如下:

  1.函數(shù)ReadDat( )實現(xiàn)從文件IN83.DAT中讀取1000個十進(jìn)制整數(shù)到數(shù)組xx中。請編制函數(shù)Compute( )分別計算出xx中偶數(shù)的個數(shù)even、奇數(shù)的平均值ave1、偶數(shù)的平均值ave2及所有偶數(shù)的方差totfc的值,最后調(diào)用函數(shù)WriteDat( )把結(jié)果輸出到OUT83.DAT文件中。

  計算方差的公式如下:

  設(shè)N為偶數(shù)的個數(shù),xx[i]為偶數(shù),ave2為偶數(shù)的平均值。

  原始數(shù)據(jù)的存放格式是:每行存放10個數(shù),并用逗號隔開(每個數(shù)均大于0且小于等于2000)。

  注意:部分源程序已給出。

  請勿改動主函數(shù)main()、讀函數(shù)ReadDat()和寫函數(shù)WriteDat()的內(nèi)容。

  試題程序:

  #include

  #include

  #include

  #define MAX 1000

  int xx[MAX],odd=0,even=0;

  double ave1=0.0,ave2=0.0,totfc=0.0;

  void WriteDat(void);

  int ReadDat(void)

  { FILE *fp;

  int i,j;

  if((fp=fopen("IN83.DAT","r"))==NULL)

  return 1;

  for(i=0;i<>

  {

  for(j=0;j<>

  fscanf(fp,"%d,",&xx[i*10+j]);

  fscanf(fp,"\n");

  if(feof(fp)) break;

  }

  fclose(fp);

  return 0;

  }

  void Compute(void)

  {

  }

  void main( )

  { int i;

  for(i=0;i

  xx[i]=0;

  if(ReadDat())

  {

  printf("數(shù)據(jù)文件IN83.DAT不能打開!\007\n");

  return;

  }

  Compute();

  printf( "EVEN=%d\nAVE1=%f\nAVE2=%f\nTOTFC=%f\n",even,ave1,ave2,

  totfc);

  WriteDat();

  }

  void WriteDat(void)

  {

  FILE *fp;

  fp=fopen("OUT83.DAT","w");

  fprintf(fp,"%d\n%lf\n%lf\n%lf\n",even,ave1,ave2,totfc);

  fclose(fp);

  }

  【答案】

  void Compute(void)

  {

  int i,tt[MAX]; /*定義數(shù)組tt計算總和*/

  for(i=0;i<1000;i++)>

  if(xx[i]%2!=0) /*判斷當(dāng)前數(shù)的奇偶性*/

  {

  odd++; /*統(tǒng)計奇數(shù)的個數(shù)*/

  ave1+=xx[i]; /*求奇數(shù)的總和*/

  }

  else

  {

  even++; /*統(tǒng)計偶數(shù)的個數(shù)*/

  ave2+=xx[i]; /*求偶數(shù)的總和*/

  tt[even-1]=xx[i]; /*將偶數(shù)存入數(shù)組tt中*/

  }

  ave1/=odd; /*求奇數(shù)的平均數(shù)*/

  ave2/=even; /*求偶數(shù)的平均數(shù)*/

  for(i=0;i

  totfc+=(tt[i]-ave2)*(tt[i]-ave2)/even;

  }

  【解析】本題主要考查的是奇偶數(shù)的判斷和方差的求法。

  用循環(huán)控制取得每一個數(shù)進(jìn)行判斷,若一個數(shù)除以2取余得0,則該數(shù)是偶數(shù),否則為奇數(shù)。分別統(tǒng)計奇數(shù)和偶數(shù)的個數(shù)、總和,并且保存所有滿足條件的偶數(shù)。最后由方差公式可知,這是求一些連續(xù)的數(shù)的表達(dá)式的和,所以可以使用循環(huán)求得方差。

  2.函數(shù)ReadDat( )的功能是實現(xiàn)從文件IN64.DAT中讀取一篇英文文章存入到字符串?dāng)?shù)組xx中。請編制函數(shù)CharConvA( ),該函數(shù)的功能是:以行為單位把字符串的最后一個字符ASCII值右移4位后加最后第二個字符的ASCII值,得到最后一個新的字符,最后第二個字符的 ASCII值右移4位后加最后第三個字符的ASCII值,得到最后第二個新的字符,以此類推一直處理到第二個字符,第一個字符的ASCII值加最后一個字符的ASCII值,得到第一個新的字符,得到的新字符分別存放在原字符串對應(yīng)的位置上,把已處理的字符串仍按行重新存入字符串?dāng)?shù)組xx中,最后調(diào)用函數(shù) WriteDat( )把結(jié)果xx輸出到文件OUT64.DAT中。

  注意:部分源程序已給出。

  原始文件存放的格式是:每行的寬度小于80個字符,含標(biāo)點符號和空格。

  請勿改動主函數(shù)main( )、讀函數(shù)ReadDat( )和寫函數(shù)WriteDat( )的內(nèi)容。

  試題程序:

  #include

  #include

  #include

  char xx[50][80];

  int maxline=0;

  int ReadDat();

  void WriteDat();

  void CharConvA(void)

  {

  }

  void main()

  {

  system("CLS");

  if (ReadDat())

  {

  printf("數(shù)據(jù)文件IN64.DAT不能打開!\n\007");

  return;

  }

  CharConvA( );

  WriteDat();

  }

  int ReadDat(void)

  {

  FILE *fp;

  int i=0;

  char *p;

  if((fp=fopen("IN64.DAT","r"))==NULL) return 1;

  while (fgets(xx[i],80,fp)!=NULL)

  {

  p=strchr(xx[i],'\n');

  if (p) *p=0;

  i++;

  }

  maxline=i;

  fclose(fp);

  return 0;

  }

  void WriteDat()

  {

  FILE *fp;

  int i;

  system("CLS");

  fp=fopen("OUT64.DAT","w");

  for(i=0;i

  {

  printf("%s\n",xx[i]);

  fprintf(fp,"%s\n",xx[i]);

  }

  fclose(fp);

  }

  【答案】

  void CharConvA(void)

  {

  int i,j,k; /*定義循環(huán)控制變量*/

  int str; /*存儲字符串長度*/

  char ch; /*暫存最后一個字符*/

  for(i=0;i

  {

  str=strlen(xx[i]); /*求得當(dāng)前行的字符串長度*/

  ch=xx[i][str-1]; /*將最后一個字符暫存入ch*/

  for(j=str-1;j>0;j--) /*從最后一個字符開始,直到第二個字符*/

  xx[i][j]=(xx[i][j]>>4)+xx[i][j-1];

  /*當(dāng)前字符ASCII值右移4位加前一個字符的ASCII值,得到新的當(dāng)前字符*/

  xx[i][0]+=ch;

  /*第一個字符的ASCII值加最后一個字符的ASCII值,得到新的第一個字符*/

  }

  }

  【解析】本題考查的是二維數(shù)組的訪問。

  首先保存最后一個字符,利用for循環(huán)由后向前逆序訪問數(shù)組中的字符。

  將當(dāng)前獲取字符的ASCII值右移4位加前一個字符的ASCII值,得到新的當(dāng)前字符。

  最后,將第一個字符的ASCII值加上保存的最后一個字符的ASCII值,得到新的第一個字符。