1. 数据的物理存储方式有4种:1)顺序存储。2)链式存储。3)索引存储。4)散列存储
2. 判断算法时间复杂度的根据是当n趋向无穷大时函数的极限,确定时间复杂度的步骤是:1)计算算法的语句频度。2)由语句频度给出时间复杂度。
例:
void f(int n)


{
int i = 91,j=100;
while(j>0)

{
if(i>100)

{
x-=10;
y--;
}
else
i++;
}
}

因为while循环与n无关,所以T(n)=O(1)。
3,一个顺序表L=(a1,a2…an),设计一个算法,要求用最少的时间把所有值为负数的元素,移动到全部值为正数的前面。
分析:题目中的“最少的时间”就意味着时间复杂度为O(n).
#include <stdio.h>

struct SqList


{
int data[20];//顺序表存储空间
int length;//当前长度
};

void Move(struct SqList &L)


{
int i = 0,j = L.length-1;
int tmp;
while(i<j)

{
while(L.data[i]<=0)i++;
while(L.data[j]>=0)j--;
if(i<j)

{
tmp = L.data[i];
L.data[i] = L.data[j];
L.data[j] = tmp;
}
}
}
void travel(struct SqList &L)


{
int i = 0;
while(i<L.length)

{
printf("%d\t",L.data[i++]);
}
}
int main()


{
struct SqList L;
int i = 0;
L.length = 10;
while(i<10)

{
L.data[i++] = -i;
L.data[i++] = i;
}
i = 0;
travel(L);
Move(L);
travel(L);
return 0;
}

4.顺序表A=(a1,a2…an,b1,b2…bm),将A换成(b1,b2…bm,a1,a2..an),要求不能够用额外的辅助空间。
分析:由于没有说m=n,所以不能够用“对应元素互换”不行,因此先将整个表逆置,再分别逆置两个子表。
void Sq_Reverse(SqList &L,int begin,int end)


{
int i,j;
ElemType tmp;
for(i=begin,j=end;i<end;i++,j--)

{
tmp = L.data[i];
L.data[i] = L.data[j];
L.data[j] = tmp;
}
}

void process(SqList &L,int m,int n)


{
Sq_Reverse(0,m+n-1);
Sq_Reverse(0,n-1);
Sq_Reverse(n,m+n-1);
}

注:比较单链表的逆置:
void Link_Reverse(LinkList &head)


{
LNode *p = head->next,*q;
head->next = NULL;
while(p!=NULL)

{
q = p->next;
p->next = head->next;
head->next = p;
p = q;
}
}

5.为了合并两个各自含有n个元素的有序表LA和LB,在最坏情况下,至少要2n-1次比较。
6.Head是带头结点的单链表的头指针,编写递归算法,逆序输出表中各个元素的值。
void Output(LNode *head)


{
if(head!=NULL)

{
Output(head->next);
printf("%d",head->data);
}
}


7.简单选择排序带头结点的双向链表
void SelectSort(DLinkList &L)


{
DLink *p,*q,*r;
p = L->next;
while(p!=NULL)

{
q = p->next;
r = p;
while(q!=NULL)

{
if(q->data<r->data) r = q;
q = q->next;
}
if(r!=p)

{
tmp = p->data;
p->data = r->data;
r->data = tmp;
}
p = p->next;
}

8,确定N个数中的第K大者。
#include <stdio.h>


int a[]=
{9,2,4,5,6,8,5,3};

int k=4,n=8;

void sort(int a[],int n)


{
int i,j,tmp;
for(i=0;i<n;i++)
for(j=i+1;j<n;j++)

{
if(a[i]<a[j])

{
tmp = a[i];
a[i] = a[j];
a[j] = tmp;
}
}
}
void travle(int a[],int n)


{
int i;
for(i=0;i<n;i++)

{
printf("%d\t",a[i]);
}
printf("\n");
}

void process(int a[],int num,int n)


{
int i=0,j;
while(i<n&&a[i]>=num)i++;
for(j=k-2;j>=i;j--)

{
a[j+1] = a[j];
}
a[i] = num;
}

int main()


{
int i;
travle(a,n);
sort(a,k);
for(i=k;i<n;i++)

{
process(a,a[i],n);
}
travle(a,n);
printf("%d\n",a[3]);
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述