#include<stdio.h> main() int a[10]=1,2,3,4,5,6,7,8,9,10,*p=&a[3],*q=p+2; printf("%d\
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了#include<stdio.h> main() int a[10]=1,2,3,4,5,6,7,8,9,10,*p=&a[3],*q=p+2; printf("%d\相关的知识,希望对你有一定的参考价值。
输出结果为什么是10??
你的程序的确很绕啊。但是在我想了一下换是明白了。:你只要把你每次改变b记下来就明白了
我给你说10吧 28也是一样的
首先b = 2; 之后fun函数传过去了a[2]的地址就是3 ,经过运算函数返回了b的值是5 ,在接着就是 b=fun(&a[i])+b;这句 最后b就被改写成了10了 最后输出就是10 第二次循环b的值是10 不是2 这个关键的 那28也就是这个道理了。明白了吧!!
这里我就是说一下为什么第一次循环是10 因为你的程序只是运行了一次,所以b的初始化只经过一次。要想在变成2,就要重新运行程序,这时候b在进行初始化,变成2.好了就这样了!!!希望对你有用!
希望对你能有所帮助。 参考技术A p=&a[3]使p指向了4,也就是*p是4;q=p+2使q指向了6,也就是*q=6。输出的是*p+*q,即4+6,不刚好是10吗?
最小生成树
1、Prim算法(适用于稠密)
# include<iostream> # include<string> # include<string.h> # include<queue> # include<stdio.h> # include<math.h> #include <algorithm> #define INF 10000001 using namespace std; int edge[505][505]; int v,e,h=1,sum = 0,ct=0; int vertex[505]; //vertex[i] 表示最小生成树的顶点集合 int temp[505]; int ans[10001]; /* struct MINI { int v,w; }mini[505][3]; //mini[i][0] 表示编号为i的顶点的v,w ,用于存储一个顶点的所有权值 bool cmp(MINI x,MINI y) { return x.w<y.w; } */ int Prim() { while(h<v) { int MINW = INF; int MINV = -1; int MINU = -1; int i,j; for(i=1;i<=h;i++) { int start = vertex[i]; for(j=1;j<=v;j++) { if(j!=start && edge[start][j]<=MINW && edge[start][j]!=INF) { for(int p=1;p<=h;p++) { if(vertex[p]==j) //如果即将加入的顶点 已经在最小生成树顶点集合中 则重新寻找 以免形成回路 continue; } //printf("%d %d %d ---------------- ",MINU,MINV,MINW); MINW = edge[start][j]; MINU = start; MINV = j; //printf("%d %d %d ---------------- ",MINU,MINV,MINW); } } } //printf("#################################################### "); h++; vertex[h] = MINV; sum += MINW; edge[MINU][MINV] = INF; edge[MINV][MINU] = INF; } return sum; } int main() { int m,n,i,j,t; cin>>t; while(t--) { cin>>v>>e; for(i=1;i<=e;i++) for(j=1;j<=e;j++) edge[i][j]=INF; for(i=1;i<=v;i++) vertex[i]=0; for(i=1;i<=10001;i++) sum[i]=0; for(i=1;i<=e;i++) { int a,b,c; scanf("%d %d %d",&a,&b,&c); edge[a][b] = c; edge[b][a] = c; } vertex[1] = 1; h = 1; sum = 0; int k = Prim(); printf("%d",k); } return 0; }
以上是关于#include<stdio.h> main() int a[10]=1,2,3,4,5,6,7,8,9,10,*p=&a[3],*q=p+2; printf("%d\的主要内容,如果未能解决你的问题,请参考以下文章