如何解决动态数组和指针符号
指针是变量还是地址?
因为int** array= new int*[4]
令人困惑。
对于此代码中的int** array
,指针成为存储指针地址的变量,而new int*[4]
变为将存储在另一个指针中的地址。
我理解错了什么?
解决方法
简单地说,指针是一个变量,可以存储另一个变量的地址,而不是jsonlite
或from typing import List
import networkx as nx
def longest_simple_paths(graph,source,target) -> List[List]:
longest_paths = []
longest_path_length = 0
for path in nx.all_simple_paths(G,source=source,target=target):
if len(path) > longest_path_length:
longest_path_length = len(path)
longest_paths.clear()
longest_paths.append(path)
elif len(path) == longest_path_length:
longest_paths.append(path)
return longest_paths
G = nx.complete_graph(4)
longest_paths = longest_simple_paths(G,source=0,target=3)
if longest_paths:
print(f"Longest simple path contains {len(longest_paths[0])} nodes")
print(longest_paths)
或诸如“ normal” 之类的其他值变量。
与其他变量一样,指针本身也有一个地址,因此您可以拥有一个指向指针的指针,即 一个存储另一个指针地址的指针。
,指针是一种数据类型,类似于int
或char
。这里的数据是一个内存地址。指针符合预期位于引用地址中的存储器中的值的类型。与其他数据类型一样,指针可以用作变量,函数参数,数组元素等的类型。
因此,int **array
是类型int **
的变量,这意味着指向位于内存中某处的类型int *
的值的指针。反过来,int *
表示指向位于存储器中某处的int
类型的值的指针。或者,简而言之,int **
是指向int
的指针。
表达式new int*[4]
表示在内存中分配类型int *[4]
的对象并返回指向它的指针。类型int *[4]
表示由类型为int *
的四个元素组成的数组,其中我们已经知道,int *
表示指向int
的值。
因此,在初始化中,左侧部分(int **
)和右侧部分(int *[]
)的类型不同。但是,如果数组元素的类型与指针引用的值的类型相同,则C ++能够自动将数组转换为指针。在我们的例子中,数组元素的类型为int *
,并且指针所指的类型相同。当数组转换为指针时,结果指针将指向数组的第一个元素。
在此声明中
int** array= new int*[4];
array
是一个变量,该变量由元素类型为int *
的动态分配数组的第一个元素的地址初始化。
如果您声明的数组类似
T array[N];
其中T
是某种类型,则可以像这样声明指向数组第一个元素的指针
T *p = array;
如果考虑到您的数组,那么T
就等于int *
。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。