C++11 数据结构0 什么是 “数据结构“?数据,数据对象,数据元素,数据项 概念。算法的基本概念 和 算法的度量,大O表示法,空间换时间的代码

这篇具有很好参考价值的文章主要介绍了C++11 数据结构0 什么是 “数据结构“?数据,数据对象,数据元素,数据项 概念。算法的基本概念 和 算法的度量,大O表示法,空间换时间的代码。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

数据:

  • 是能输入计算机且能被计算机处理的各种符号的集合。
  • 数值型的数据:整数和实数。
  • 非数值型的数据:文字、图像、图形、声音等。

数据对象:

        性质相同的 "数据元素" 的集合

        例如一个 int arr[10],  Teacher tea[3];

数据元素: 

        tea[0],tea[1],arr[2],这些都是

数据项:

        数据元素中的每一项。

数据结构就是研究 数据元素之间关系的,注意这门课研究的位置和方向。

算法的概念:

特定问题的求解步骤的描述。

算法复杂度:大O法表示

用空间来换取时间的一个例子:

//有一个数组,统计这个数组中的数组都是由1-999 组成的,统计这个数组中那个 数字出现的最多,并打印出现的次数

#include <iostream>
using namespace std;

void search(int *array, int len) {
	int sp[1000] = { 0 }; //都清空成0
	int i = 0; 
	int max = 0;
	for (i = 0; i < len;++i) {//遍历数组。将数组的值做为sp数组的下标,每出现一次,则+1
		int index = array[i] - 1;
		sp[index] ++;//也就是说,如果碰到array[100] = 11,则将sp[10]的值++,
	}

	//找出出现最多的次数,赋值给max
	for (i = 0; i < 1000;++i) {
		if (max<sp[i]) {
			max = sp[i];
		}
	}

	//找到了出现最多的次数,还要根据这个次数找到array的值。这里要好好的理解一下
	for (i = 0; i < 1000;++i) {
		if (max == sp[i]) {
			cout << "出现最多的是" << i+1 <<" 出现的次数是 :" << max << endl;
		}
	}
}

int main()
{
    std::cout << "Hello World!\n";
	//有一个数组,统计这个数组中的数组都是由1-999 组成的,统计这个数组中那个 数字出现的最多,并打印出现的次数
	int array[] = { 178,2,33,4,5,6,4,3,2,1,23,6,6,6,3,45,46,45,6,6,6,6,6,6,6,6,999 };
	cout << "sizeof(array)" << sizeof(array)<< endl;
	cout << "sizeof(*array)" << sizeof(*array) << endl;
	cout << "*array = " << *array << endl;
	search(array,sizeof(array)/sizeof(*array));
}


数据结构:

数据结构就是研究 数据元素之间关系的,注意这门课研究的位置和方向。

那么具体要学些啥呢?

1.一般线性表的顺序实现,实际上就是数组

2.一般线性表的链式存储 --单链表

3.一般线性表的链式存储 --双链表

4.一般线性表的链式存储 --循环链表

5.栈的顺序存储

6.栈的链式存储

7.队列的顺序存储

8.队列的链式存储

9.然后再研究树。树的知识点是以学好前面的知识为基础的,因此要先学好前面的线性表 相关的。然后再学习树

        

C++11 数据结构0 什么是 “数据结构“?数据,数据对象,数据元素,数据项 概念。算法的基本概念 和 算法的度量,大O表示法,空间换时间的代码,数据结构文章来源地址https://www.toymoban.com/news/detail-851647.html

到了这里,关于C++11 数据结构0 什么是 “数据结构“?数据,数据对象,数据元素,数据项 概念。算法的基本概念 和 算法的度量,大O表示法,空间换时间的代码的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【数据结构OJ题】移除链表元素

    原题链接:力扣  给你一个链表的头节点  head  和一个整数  val  ,请你删除链表中所有满足  Node.val == val  的节点,并返回 新的头节点  。  方法一:原地删除节点 思路:  首先,定义两个指针:prve和cur。它们会在遍历链表的过程中分别指向当前节点的前一个节点和当前

    2024年02月11日
    浏览(29)
  • 【Python】【数据结构和算法】保留最后N个元素

    使用 deque ,指定 maxlen 参数的值为N,例如: Python Cookbook 1.3

    2024年02月11日
    浏览(29)
  • LeetCode 刷题 数据结构 链表 203 移除链表元素

    Given the  head  of a linked list and an integer  val , remove all the nodes of the linked list that has  Node.val == val , and return  the new head . Example 1: Example 2: Example 3: Constraints: The number of nodes in the list is in the range  [0, 104] . 1 = Node.val = 50 0 = val = 50 今天leetcode的中文官网比较卡,所以是登录官网进行

    2024年02月14日
    浏览(27)
  • 【数据结构】移除链表元素-图文解析(单链表OJ题)

    LeetCode链接:203. 移除链表元素 - 力扣(LeetCode) 本文导航 💭做题思路 🎨画图更好理解: ✍️代码实现 🗂️分情况讨论: ❄️极端情况: 遍历链表,找到值为 val 的节点删除 这里需要两个指针  cur 用来遍历链表  prev 指向 cur 的前一个位置,方便删除一个节点后,链接前

    2024年02月14日
    浏览(27)
  • 数据结构——顺序表——数组元素和与数字和的绝对差

    经验:要得到一个数的个位和十位,可以通过先模十取余,再除于十

    2024年04月12日
    浏览(31)
  • Redis数据结构与对象-字符串对象SDS

    Redis没有使用C的字符串,而是自己构建了简单动态字符串(Simple Dynamic String),简称SDS。通过这种字符串格式能够对redis字符串操作进行提速。下面介绍原理。 sds数据格式如下: 比如,一个sds 中存的是 “Redis” ,那么buf 中是一个char型的数组,存5个字符R, e,d,i,s len =5;free

    2023年04月16日
    浏览(36)
  • 【数据结构】Java对象的比较

    作者主页: paper jie_博客 本文作者:大家好,我是paper jie,感谢你阅读本文,欢迎一建三连哦。 本文录入于《JAVA数据结构》专栏,本专栏是针对于大学生,编程小白精心打造的。笔者用重金(时间和精力)打造,将javaSE基础知识一网打尽,希望可以帮到读者们哦。 其他专栏:

    2024年02月08日
    浏览(50)
  • 数据结构入门-11-红黑树

    史上最负盛名的平衡二叉树–红黑树,但其实就是2-3树的一种实现 也是BST,每一个节点都有颜色 性质 看 后面推导出来的结论 2-3树 :和红黑树是等价的 满足BST的基本性质,但不是一种二叉树 有两种节点: 2-3 绝对平衡:根节点到叶子节点 一定相同 2.3.1 如何维护绝对平衡

    2023年04月17日
    浏览(32)
  • 【数据结构】顺序栈的基本操作:出栈、入栈、取栈顶元素、输出所有栈中元素、括号匹配题目

    栈是限定仅在表位进行插入或删除操作的线性表。栈的表尾称为栈顶,表头称为栈底。不含元素的栈称为空栈。 左图为栈的示意图,右图为用铁路调度表示栈。 如下是入栈至栈满再进行出栈的过程示意图。值得注意的是,栈满后,top指针指向的不是顶端元素,而是顶端的下

    2024年02月07日
    浏览(41)
  • 【数据结构】栈——共享栈、链栈(入栈 出栈 判空 创建 读栈顶元素)完整代码

    只允许在一端进行插入操作或删除的线性表。 重要术语 栈顶:允许 插入和删除的一端。 栈底:不允许 插入删除的一端。 空栈:不含任何元素的空表。 出栈顺序(卡特兰数): n个不同元素进栈,出栈元素不同排列的个数: 1 n + 1 C 2 n n frac{1}{n+1} quad C_{2n}^n n + 1 1 ​ C 2 n n ​

    2024年02月11日
    浏览(26)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包