如何解决插入和大 O 符号
我是 C 编程的新手。我对数组中的插入有疑问。例如在 c 和 java 中我们不能在数组的末尾插入一个新元素,它会产生一个错误(例如我们初始化一个大小为 5 的数组并在末尾插入一个新元素)。在这种情况下,我们需要创建一个新数组并将前一个数组中的所有元素复制到这个数组中并删除前一个数组。所以这里的空间复杂度是 O(1)。我的问题是这里的时间复杂度是多少。在一篇博客中,我看到它是 O(n),但不是 O(2n)。首先我们创建一个新的数组时间复杂度 O(n) 然后删除以前的数组时间复杂度 O(n) 所以总时间复杂度必须是 O(2n) ?你们能帮我吗...
解决方法
创建/删除(malloc/free)一块内存不是 O(n) 而是 O(1) 复杂度。将元素从一个内存块复制/移动到另一个内存块将是 O(n)。
如果您必须为每个元素调用构造函数/析构函数,那么您的复杂度确实为 O(2n),但如果您只是“移动”元素,那么复杂度将为 O(n)。
但是就像上面评论中已经提到的用户 prog-fh 一样,O(2n) 是 O(n)。
注意:在C中,您可以通过memcpy
复制一块内存,我只考虑了元素方式(例如调用元素复制函数或元素赋值操作)。
是的,您在技术上是正确的。在此之前,我们必须了解用于时间复杂度的符号。
Big-O 表示法:O(n) 只是上限(最坏情况)的近似值,而不是确切值,这意味着它可以等于 O(c.n)。 这里正如你所说的 c 是 2。
所以粗略的近似值是 O(n)。了解我们使用的符号只是近似值。
关于时间复杂度和符号的有用文章:here
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。