2
3
4
5
6
7
8
9
10
知識:
1.數(shù)據(jù)結(jié)構(gòu)中對象的定義,存儲的表示及操作的實現(xiàn).
2.線性:線性表、棧、隊列、數(shù)組、字符串(廣義表不考)
樹:二叉樹
集合:查找,排序
圖(不考)
能力:
分析,解決問題的能力
過程:
● 確定問題的數(shù)據(jù)。
● 確定數(shù)據(jù)間的關(guān)系。
● 確定存儲結(jié)構(gòu)(順序-數(shù)組、鏈表-指針)
● 確定算法
● 編程
● 算法評價(時間和空間復(fù)雜度,主要考時間復(fù)雜度)
一、數(shù)組
1、存放于一個連續(xù)的空間
2、一維~多維數(shù)組的地址計算方式
已知data[0][0]的內(nèi)存地址,且已知一個元素所占內(nèi)存空間S求data[i][j]在內(nèi)存中的地址。
公式:(add+(i*12+j)*S)(假設(shè)此數(shù)組為data[10][12])
注意:起始地址不是data[0][0]時候的情況。起始地址為data[-3][8]和情況;
3、順序表的定義
存儲表示及相關(guān)操作
4、順序表操作中時間復(fù)雜度估計
5、字符串的定義(字符串就是線性表),存儲表示
模式匹配算法(簡單和KMP(不考))
6、特殊矩陣:存儲方法(壓縮存儲(按行,按列))
三對角:存儲于一維數(shù)組
三對角問題:已知Aij能求出在一維數(shù)組中的下標(biāo)k;已知下標(biāo)k求Aij。
7、稀疏矩陣:定義,存儲方式:三元組表、十字鏈表(屬于圖部分,不考)
算法
● 數(shù)組中元素的原地逆置; 對換
● 在順序表中搜索值為X的元素;
● 在有序表中搜索值為X的元素;(折半查找)
● 在順序表中的第i個位置插入元素X;
● 在順序表中的第i個位置刪除元素X;
● 兩個有序表的合并;算法?
線性表數(shù)據(jù)結(jié)構(gòu)定義:
Typedef struct {
int data[max_size];
int len;
}linear_list;
● 模式匹配
● 字符串相加
● 求子串
● (i,j)<=>K 注意:不同矩陣所用的公式不同;
● 稀疏矩陣的轉(zhuǎn)置(兩種方式,后種為妙)
● 和數(shù)組有關(guān)的算法
例程:求兩個長整數(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進位 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.否則為隨機數(shù); 較小的整數(shù)高位賦0.
算法:已知a,b兩個長整數(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);
}
時間復(fù)雜度計算:
● 確定基本操作
● 計算基本操作次數(shù)
● 選擇T(n)
● lim(F(n)/T(n))=c
● 0(T(n))為時間復(fù)雜度
上例子的時間復(fù)雜度為O(max_s);
[1] [2] [3] [4] [5] [6] [7] [8] [9] 下一頁
轉(zhuǎn)帖于:軟件水平考試_考試吧- 推薦給朋友
- 收藏此頁
·網(wǎng)絡(luò)工程師資料:網(wǎng)絡(luò)體系結(jié)構(gòu)-軟考網(wǎng)絡(luò)類題解 (2008-4-25 14:33:38)
·計算機網(wǎng)絡(luò)基礎(chǔ)網(wǎng)絡(luò)拓撲結(jié)構(gòu)及優(yōu)缺點分析 (2008-2-22 14:04:32)
·網(wǎng)絡(luò)工程師必知:靜態(tài)路由協(xié)議配置方法 (2008-2-22 14:03:39)
·計算機網(wǎng)絡(luò)尼奎斯特 香農(nóng)公式例題解析 (2008-2-22 14:02:35)
·軟考復(fù)習(xí):因特網(wǎng)IP的分類、尋址規(guī)則及子網(wǎng)掩碼 (2008-2-22 13:57:21)
如果軟件水平考試網(wǎng)所轉(zhuǎn)載內(nèi)容不慎侵犯了您的權(quán)益,請與我們聯(lián)系,我們將會及時處理。如轉(zhuǎn)載本軟件水平考試網(wǎng)內(nèi)容,請注明出處。