服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - 一篇文章带你入门C语言数据结构:绪论

一篇文章带你入门C语言数据结构:绪论

2021-12-10 14:54AKA你的闺蜜 C/C++

这篇文章主要介绍了C语言的数据解构基础,希望对广大的程序爱好者有所帮助,同时祝大家有一个好成绩,需要的朋友可以参考下,希望能给你带来帮助

绪论

什么是数据结构?

不同于计算机操作培训,注意与程序设计的区别。

example 1

求n个数的最大值、次最大值。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
//1.遍历 - 最朴素的方法
int main()
{
    int arr[10] = { 22,334,552,1,4,6,78,23,55,98 };
    int i = 0;
    int temp = 0;
    int max1 = arr[0];
    int max2 = arr[1];
    for (i = 1; i < 10; i++)
    {
        if (arr[i] > max1)
        {
            temp = max1;
            max1 = arr[i];
            arr[i] = temp;
        }
    }
    printf("%d\n", max1);
    for (i = 2; i < 10; i++)
    {
        if (arr[i] > max2)
        {
            temp = max2;
            max2 = arr[i];          arr[i] = temp;
        }
    }
    printf("%d\n", max2);
    return 0;
}
遍历方法共需进行 n − 1 + n − 2 = 2 n − 3 n-1+n-2=2n-3 n−1+n−2=2n−3次比较。

变题

有n个足球队比赛,问至少多少次比赛才能找到冠军和亚军。

解:
实际中通常采用锦标赛方法。(淘汰制)
设有8个数分别为5,7,3,6,8,9,4,2
两两为一组进行比较,大的胜出,小的淘汰。

一篇文章带你入门C语言数据结构:绪论

毋庸置疑的是,无论怎么分组,显然最大值永远不会被淘汰。故最大值为9。

共进行了 8 / 2 + 4 / 2 + 2 / 2 = 7 8/2+4/2+2/2=7 8/2+4/2+2/2=7次比较。

故变题寻找冠军的比较次数为 n / 2 + n / 2 2 + … + n / 2 k = n − 1 n/2+n/2^2+…+n/2^k=n-1 n/2+n/22+…+n/2k=n−1

一篇文章带你入门C语言数据结构:绪论

次最大值肯定是被最大值给比下去了,不然它就是最大值了。所以顺着这个思路,把所有和最大值进行过直接比较的数字跳出来,重新进行比较。

就是如图所示带*的数字,个数记为k,稍加思索则得出 k = l o g 2 n k=log_2{n} k=log2​n

2.故变题寻找亚军的比较次数为 l o g 2 n − 1 log_2{n}-1 log2​n−1

锦标赛方法共需 n − 1 + l o g 2 n − 1 = n + l o g 2 n − 2 n-1+log_2{n}-1=n+log_2{n}-2 n−1+log2​n−1=n+log2​n−2次比较。

课后思考:将该模型用c程序编写出来。

讨论

​ 处理一般实际工程问题的方法。

  • 找出解决方案。
  • 找出最优解。(最节省资源:cpu和内存)

一篇文章带你入门C语言数据结构:绪论

example 2

判断表达式中括号是否匹配

z = ( ( a + b ) + c ) ∗ 2 + ( 3 − 5 ) / 7 − ( ( 6 + 2 ) / 8 + a )

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
void match(char* ch)
{
    int count = 0;
    int i = 0;
    while (ch[i]!= ';')
    {
        if(ch[i] == '(')
            count++;
        else if (ch[i] ==')')
            count--;
        i++;
    }
    if (count != 0)
        printf("%s\n","no match");
    else
        printf("%s\n","match");
}

当然,上述代码是由左向右数括号数是否相等来判断括号是否匹配,很容易就可以举出反例 f = ) a + b ( f=)a+b( f=)a+b( ,所有该方法是不成熟的。

example 3

交叉路口交通管理系统

一篇文章带你入门C语言数据结构:绪论

  • 把可以走通的道路设为顶点
  • 如果两个顶点有冲突,用顶点之间的连线表示

变题 着色算法

在状态图中,相邻(有连线)的顶点不能是同一种状态。故对于顶点的不同状态,我们用不同的颜色去表示。由于四色定理,多余5叉的路口不能用少于4种颜色来表示。

在状态图中至少需要多少种颜色来表示?

example 4

如何快速走出迷宫?

一篇文章带你入门C语言数据结构:绪论

以上问题现阶段并不作要求,目的是向大家介绍下数据结构的研究问题。

现在我们是否能回答出刚开始时问大家的问题呢?数据结构是什么?

数据结构是研究的是非数值计算的程序设计方法。

一篇文章带你入门C语言数据结构:绪论

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注服务器之家的更多内容!

原文链接:https://blog.csdn.net/yourfriendyo/article/details/118763122

延伸 · 阅读

精彩推荐
  • C/C++深入C++拷贝构造函数的总结详解

    深入C++拷贝构造函数的总结详解

    本篇文章是对C++中拷贝构造函数进行了总结与介绍。需要的朋友参考下...

    C++教程网5182020-11-30
  • C/C++使用C++制作简单的web服务器(续)

    使用C++制作简单的web服务器(续)

    本文承接上文《使用C++制作简单的web服务器》,把web服务器做的功能稍微强大些,主要增加的功能是从文件中读取网页并返回给客户端,而不是把网页代码...

    C++教程网5492021-02-22
  • C/C++关于C语言中E-R图的详解

    关于C语言中E-R图的详解

    今天小编就为大家分享一篇关于关于C语言中E-R图的详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看...

    Struggler095962021-07-12
  • C/C++c/c++内存分配大小实例讲解

    c/c++内存分配大小实例讲解

    在本篇文章里小编给大家整理了一篇关于c/c++内存分配大小实例讲解内容,有需要的朋友们可以跟着学习参考下。...

    jihite5172022-02-22
  • C/C++c/c++实现获取域名的IP地址

    c/c++实现获取域名的IP地址

    本文给大家汇总介绍了使用c/c++实现获取域名的IP地址的几种方法以及这些方法的核心函数gethostbyname的详细用法,非常的实用,有需要的小伙伴可以参考下...

    C++教程网10262021-03-16
  • C/C++OpenCV实现拼接图像的简单方法

    OpenCV实现拼接图像的简单方法

    这篇文章主要为大家详细介绍了OpenCV实现拼接图像的简单方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    iteye_183805102021-07-29
  • C/C++C语言main函数的三种形式实例详解

    C语言main函数的三种形式实例详解

    这篇文章主要介绍了 C语言main函数的三种形式实例详解的相关资料,需要的朋友可以参考下...

    ieearth6912021-05-16
  • C/C++C语言实现双人五子棋游戏

    C语言实现双人五子棋游戏

    这篇文章主要为大家详细介绍了C语言实现双人五子棋游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    两片空白7312021-11-12