av手机免费在线观看,国产女人在线视频,国产xxxx免费,捆绑调教一二三区,97影院最新理论片,色之久久综合,国产精品日韩欧美一区二区三区

試題

三級(jí)網(wǎng)絡(luò)技術(shù)上機(jī)題及答案

時(shí)間:2025-02-28 09:29:06 試題 我要投稿

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

  函數(shù)ReadDat()的功能是實(shí)現(xiàn)從文件IN67.DAT中讀取一篇英文文章存入到字符串?dāng)?shù)組xx中;請(qǐng)編制函數(shù)StrOL(),該函數(shù)的功能是:以行為單位對(duì)行中以空格或標(biāo)點(diǎn)符號(hào)為分隔的所有單詞進(jìn)行倒排。最后把已處理的字符串(應(yīng)不含標(biāo)點(diǎn)符號(hào))仍按行重新存入字符串?dāng)?shù)組xx中,最后調(diào)用函數(shù) WriteDat()把結(jié)果xx輸出到文件OUT67.DAT中。

  例如,原文:You He Me

  I am a student.

  結(jié)果:Me He You

  student a am I

  原始數(shù)據(jù)文件存放的格式是:每行的寬度均小于80個(gè)字符,含標(biāo)點(diǎn)符號(hào)和空格。

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

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

  試題程序:

  #include

  #include

  #include

  #include

  #include

  char xx[50][80];

  int maxline = 0;/* 文章的總行數(shù) */

  int ReadDat(void);

  void WriteDat(void);

  void StrOL(void)

  {

  }

  void main()

  {

  system("CLS");

  if (ReadDat ())

  {

  printf("數(shù)據(jù)文件 IN67.DAT不能打開!n07");

  return;

  }

  StrOL();

  WriteDat();

  }

  int ReadDat(void)

  {

  FILE *fp;

  int i = 0;

  char *p;

  if((fp = fopen("IN67.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(void)

  {

  FILE*fp;

  int i;

  system("CLS");

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

  for(i = 0; i < maxline;="" i++)="">

  {

  printf("%sn", xx[i]);

  fprintf(fp, "%sn", xx[i]);

  }

  fclose(fp);

  }

  【參考答案】

  void StrOL(void)

  {

  int i,j,k; /*定義數(shù)組下標(biāo)變量*/

  char t[80],t1[80]; /*定義數(shù)組暫存取得的單詞*/

  for(i=0;i

  {

  j=k=strlen(xx[i])-1; /*將每行末尾字符的下標(biāo)保存在j和k中*/

  t[0]=t1[0]=''; /*初始化兩個(gè)字符數(shù)組*/

  while(1) /*無條件循環(huán),循環(huán)體內(nèi)有結(jié)束循環(huán)的語句*/

  {

  while(isalpha(xx[i][j])==0&&j>=0)

  /*若以j為下標(biāo)的字符不是字母并且還在數(shù)組xx之內(nèi)*/

  k=--j;

  while(isalpha(xx[i][j])&&j>=0)

  /*若以j為下標(biāo)的字符是字母并且還在數(shù)組xx之內(nèi)*/

  j--;

  /*當(dāng)退出這個(gè)循環(huán)時(shí),xx[i][j+1]和xx[i][k]分別是同一個(gè)單詞的第一個(gè)和最后一個(gè)字母*/

  memcpy(t1,&xx[i][j+1],k-j); /*將該單詞保存到字符數(shù)組t1*/

  t1[k-j]=''; /*為t1中的單詞添加字符串結(jié)束標(biāo)志*/

  strcat(t,t1); /*將單詞保存到數(shù)組t中*/

  strcat(t," "); /*單詞之間用空格分隔*/

  if(j<0)>

  break; /*則退出外層while循環(huán)*/

  }

  strcpy(xx[i],t); /*按行將處理完了字符串重新保存到數(shù)組xx中*/

  }

  }

  【解析】

  本題的主要算法是先讓兩字符指針都指向每一行字符的串尾,然后使其中一指針(p1)往前移動(dòng),當(dāng)出現(xiàn)pl指向的不是字母時(shí)則表示在p1+1與 p2之間是一個(gè)單詞,將該單詞存入字符數(shù)組t1中,最后將t1連接到新串t中;接著再往前找第二個(gè)單詞,依次類推直到p1越過字符串的起始位置。再將處理完的字符串重新儲(chǔ)存到數(shù)組xx中,然后進(jìn)入下一行的處理過程。

【三級(jí)網(wǎng)絡(luò)技術(shù)上機(jī)題及答案】相關(guān)文章:

2016最新三級(jí)網(wǎng)絡(luò)技術(shù)上機(jī)題及答案10-08

2016計(jì)算機(jī)三級(jí)網(wǎng)絡(luò)技術(shù)上機(jī)題及答案07-28

2016年3月三級(jí)網(wǎng)絡(luò)技術(shù)上機(jī)題及答案05-23

2017計(jì)算機(jī)三級(jí)《網(wǎng)絡(luò)技術(shù)》上機(jī)操作題及答案07-20

2016計(jì)算機(jī)考試三級(jí)網(wǎng)絡(luò)技術(shù)上機(jī)題及答案08-26

2016最新三級(jí)網(wǎng)絡(luò)技術(shù)上機(jī)試題及答案08-20

2016全國(guó)三級(jí)網(wǎng)絡(luò)技術(shù)上機(jī)試題及答案09-07

計(jì)算機(jī)三級(jí)網(wǎng)絡(luò)技術(shù)上機(jī)題庫(kù)及答案05-13

2016年計(jì)算機(jī)等級(jí)考試三級(jí)網(wǎng)絡(luò)技術(shù)上機(jī)題及答案08-22