查看全部128種考試
軟件水平考試
 考試動態(tài) 報(bào)考指南 歷年真題 模擬試題 復(fù)習(xí)資料 心得技巧 專業(yè)英語 技術(shù)文章 軟考論壇 考試用書
 程序員 軟件設(shè)計(jì)師 網(wǎng)絡(luò)管理員 網(wǎng)絡(luò)工程師 系統(tǒng)分析師 數(shù)據(jù)庫系統(tǒng)工程師
1
2
3
4
5
6
7
8
9
10
ak47  
【字體: 程序員考試:數(shù)據(jù)結(jié)構(gòu)筆記
程序員考試:數(shù)據(jù)結(jié)構(gòu)筆記
spks.exam8.com 來源:考試吧Exam8.com) 更新:2005-3-25 11:20:00 軟件水平考試 考試論壇

知識:

  1.數(shù)據(jù)結(jié)構(gòu)中對象的定義,存儲的表示及操作的實(shí)現(xiàn).
  2.線性:線性表、棧、隊(duì)列、數(shù)組、字符串(廣義表不考)
   樹:二叉樹
   集合:查找,排序
   圖(不考)

能力

  分析,解決問題的能力

過程

  ● 確定問題的數(shù)據(jù)。
  ● 確定數(shù)據(jù)間的關(guān)系。
  ● 確定存儲結(jié)構(gòu)(順序-數(shù)組、鏈表-指針)
  ● 確定算法
  ● 編程
  ● 算法評價(jià)(時(shí)間和空間復(fù)雜度,主要考時(shí)間復(fù)雜度)

一、數(shù)組

  1、存放于一個(gè)連續(xù)的空間
  2、一維~多維數(shù)組的地址計(jì)算方式
   已知data[0][0]的內(nèi)存地址,且已知一個(gè)元素所占內(nèi)存空間S求data[i][j]在內(nèi)存中的地址。
   公式:(add+(i*12+j)*S)(假設(shè)此數(shù)組為data[10][12])

  注意:起始地址不是data[0][0]時(shí)候的情況。起始地址為data[-3][8]和情況;

  3、順序表的定義
   存儲表示及相關(guān)操作
  4、順序表操作中時(shí)間復(fù)雜度估計(jì)
  5、字符串的定義(字符串就是線性表),存儲表示
   模式匹配算法(簡單和KMP(不考))
  6、特殊矩陣:存儲方法(壓縮存儲(按行,按列))
   三對角:存儲于一維數(shù)組
   三對角問題:已知Aij能求出在一維數(shù)組中的下標(biāo)k;已知下標(biāo)k求Aij。
  7、稀疏矩陣:定義,存儲方式:三元組表、十字鏈表(屬于圖部分,不考)

  算法

  ● 數(shù)組中元素的原地逆置; 對換
  ● 在順序表中搜索值為X的元素;
  ● 在有序表中搜索值為X的元素;(折半查找)
  ● 在順序表中的第i個(gè)位置插入元素X;
  ● 在順序表中的第i個(gè)位置刪除元素X;
  ● 兩個(gè)有序表的合并;算法?


  線性表數(shù)據(jù)結(jié)構(gòu)定義:
   Typedef struct {
    int data[max_size];
    int len;
   }linear_list;
  ● 模式匹配
  ● 字符串相加
  ● 求子串
  ● (i,j)<=>K 注意:不同矩陣所用的公式不同;
  ● 稀疏矩陣的轉(zhuǎn)置(兩種方式,后種為妙)
  ● 和數(shù)組有關(guān)的算法

  例程:求兩個(gè)長整數(shù)之和。

  a=13056952168
  b=87081299
  數(shù)組:
  a[]:1 3 0 5 6 9 5 2 1 6 8
  b[]:8 7 0 8 1 2 9 9 
  由于以上的結(jié)構(gòu)不夠直觀(一般越是直觀越容易解決) 將其改為:
  a[]:11 8 6 1 2 5 9 6 5 0 3 1 a[0]=11(位數(shù))
  b[]: 8 9 9 2 1 8 0 7 8 0 0 0 b[0]=8
  c進(jìn)位 0 1 1 0 0 1 1 1 1 0 0 
  c[]:11 7 6 4 3 3 0 4 4 2 3 1 c[0]的值(C位數(shù))由c[max_s+1]決定!
  注意:在求C前應(yīng)該將C(max_s+1)位賦0.否則為隨機(jī)數(shù); 較小的整數(shù)高位賦0.
  算法:已知a,b兩個(gè)長整數(shù),結(jié)果:c=a+b;
  總共相加次數(shù): max_s=max(a[],b[])
  程序:
  for(i=1;i<=max_s;i++) {
   k=a[i]+b[i]+c[i];
   c[i]=k%10;
   c[i+1]=k/10;
  }
  求c位數(shù):
  if(c[max_s+1]==0)
   c[0]=max_s;
  else
   c[0]=max_s+1;
  以下代碼是我編的(畢竟是初學(xué)者.不太簡潔大家不要見怪!):
  /*兩長整數(shù)相加*/
   #include<stdio.h>
   #include<string.h>
  #define PRIN printf("\n");

  int flag=0; /*a[0]>b[0]?1:0*/

  /* max(a[],b[]) {}*/

  change(char da[],char db[],int a[],int b[],int c[]) {
   int i;
   if(a[0]>b[0]) {
    for(i=1;i<=a[0];a[i]=da[a[0]-i]-'0',i++); /*a[0]-'0' so good!*/
    for(i=1;i<=b[0];b[i]=db[b[0]-i]-'0',i++);
    for(i=b[0]+1;i<=a[0];b[i]=0,i++);
    for(i=1;i<=a[0]+1;c[i]=0,i++);
    flag=1;
   }
   else {
    for(i=1;i<=b[0];b[i]=db[b[0]-i]-'0',i++);
    for(i=1;i<=a[0];a[i]=da[a[0]-i]-'0',i++);
    for(i=a[0]+1;i<=b[0];a[i]=0,i++);
    for(i=1;i<=b[0]+1;c[i]=0,i++);
   }
  }

  add(int a[],int b[],int c[]) {
   int i,sum;
   if(flag==1) {
    for(i=1;i<=a[0];i++) {
     sum=a[i]+b[i]+c[i];
     c[i+1]=sum/10;
     c[i]=sum%10;
    }
    if(c[a[0]+1]==0)
     c[0]=a[0];
    else
     c[0]=a[0]+1;
   }
   else {
    for(i=1;i<=b[0];i++) {
     sum=a[i]+b[i]+c[i];
     c[i+1]=sum/10;
     c[i]=sum%10;
    }
    if(c[b[0]+1]==0)
     c[0]=b[0];
    else
     c[0]=b[0]+1;
   }
  }

  void print(int m[]) {
   int i;
   for(i=m[0];i>=1;i--)
    printf("%d,",m[i]); PRIN
  }

  main(){
   int s;
   int a[20],b[20],c[20];
   char da[]={"123456789"};
   char db[]={"12344443"};
   a[0]=strlen(da);
   b[0]=strlen(db);
   printf("a[0]=%d\t",a[0]);
   printf("b[0]=%d",b[0]); PRIN
   change(da,db,a,b,c);
   printf("flag=%d\n",flag); PRIN
   printf("-----------------\n");
   if(flag==1) {
    print(a); PRIN
    s=abs(a[0]-b[0]);
    printf("+");
     for(s=s*2-1;s>0;s--)
      printf(" ");
      print(b); PRIN
   }
   else {
    s=abs(a[0]-b[0]);
    printf("+");
    for(s=s*2-1;s>0;s--)
     printf(" ");
     print(a); PRIN
     print(b); PRIN
   }
   add(a,b,c);
   printf("-----------------\n");
   print(c);
  }

時(shí)間復(fù)雜度計(jì)算:

  ● 確定基本操作
  ● 計(jì)算基本操作次數(shù)
  ● 選擇T(n)
  ● lim(F(n)/T(n))=c
  ● 0(T(n))為時(shí)間復(fù)雜度
  上例子的時(shí)間復(fù)雜度為O(max_s);

[1] [2] [3] [4] [5] [6] [7] [8] [9] 下一頁

轉(zhuǎn)帖于:軟件水平考試_考試吧
文章搜索  
看了本文的網(wǎng)友還看了:
網(wǎng)友評論
昵 稱: *  評 分: 1分 2分 3分 4分 5分
標(biāo)題:   匿名發(fā)表    (共有條評論)查看全部評論>>
版權(quán)聲明 -------------------------------------------------------------------------------------
  如果軟件水平考試網(wǎng)所轉(zhuǎn)載內(nèi)容不慎侵犯了您的權(quán)益,請與我們聯(lián)系,我們將會及時(shí)處理。如轉(zhuǎn)載本軟件水平考試網(wǎng)內(nèi)容,請注明出處。
關(guān)于本站  網(wǎng)站聲明  廣告服務(wù)  聯(lián)系方式  付款方式  站內(nèi)導(dǎo)航  客服中心  友情鏈接  考試論壇  網(wǎng)站地圖
Copyright © 2004-2008 考試吧軟件水平考試網(wǎng) All Rights Reserved    
中國科學(xué)院研究生院權(quán)威支持(北京) 電 話:010-62168566 傳 真:010-62192699
百度大聯(lián)盟黃金認(rèn)證  十佳網(wǎng)絡(luò)教育機(jī)構(gòu)  經(jīng)營許可證號:京ICP060677