文档详情

C课件第五章.ppt

发布:2017-05-28约9.69千字共51页下载文档
文本预览下载声明
* * p2=a+4; //指针变量p2,直接由数组名加上4,指向数组的第五个数组元素的内存单元 if(p1p2)coutp1所指向的数组元素在p2所指向的数组元素前面!endl; else coutp1所指向的数组元素在p2所指向的数组元素后面!endl; p1++; p2--; if(p1==p2)coutp1和p2同时指向数组中的同一个元素且元素值为:*p1endl; else coutp1和p2没有指向数组中的同一个元素!endl; } * * 例5.8、利用指针技术,将键盘输入的N个整数按相反的顺序存放并输出。 思路分析: 分别取出数组最前面和最后面的元素,进行交换,即a[0]与a[N-1]交换;然后再分别取出a[1]与a[N-2]交换;直到交换完毕。 * * 源程序清单: #include iostream #include iomanip using namespace std; int main(void) { int a[10],i,j,temp,*p; coutInput ten interger:endl; for(p=a;pa+10;p++) cin*p; p=a; * * for(i=0,j=10-1;ij;i++,j--) { temp=*(p+i); *(p+i)=*(p+j); *(p+j)=temp; } for(p=a;pa+10;p++) coutsetw(4)*p; coutendl; return 0; } * * 例5.9、把一个整数插入到一个由小到大的有序整数序列中,并仍然保持由小到大的顺序。 设有10个整数按由小到大的顺序存放在数组a中,待插入的数放在变量x中。 #includeiostream #include iomanip using namespace std; void main(void) { const int N=10; int a[N+1],p,x,*t; * * cout输入a数组:endl; for(t=a;ta+N;t++) cin*t; cout输入待插入的数x:endl; cinx; t=a;p=0; while (x*(t+p)pN) p++; for (t=a+N-1;t=a+p;t--) *(t+1)=*t; t=a+p; *t=x; for (t=a;t=a+N;t++) coutsetw(3)*t; coutendl; } * * 例5.10、从键盘输入整数集合a、b的元素个数和各个元素的值(不相同),计算并输出其交集。 #include iostream using namespace std; #include iomanip void main(void) { const int M=20,N=10; int a[M],b[N],c[M]; int d,e,f=0,*pa,*pb,*pc; * * cout输入数组a中元素的个数:endl; cind; cout输入数组a的d个元素:endl; for(pa=a;paa+d;pa++) cin*pa; cout输入数组b中元素的个数:endl; cine; cout输入数组b的e个元素:endl; for(pb=b;pbb+e;pb++) cin*pb; * * for(pa=a,pc=c;paa+d;pa++) for(pb=b;pbb+e;pb++) if(*pa==*pb) {*pc++=*pa; f++; break;} cout交集c的各个元素依次为:endl; for(pc=c;pcc+f;pc++) coutsetw(3)*pc; coutendl; } * * 例5.11、从键盘输入整数集合a、b的元素个数和各个元素的值(不相同) ,计算并输出其并集。 #include iostream using namespace std; #include iomanip void main(void) { const int M=20,N=10; int a[M],b[N],c[M+N]; int d,e,f=0,*pa,*pb,*pc; * * cout输入数组a中元素的个数:endl; cind; cout输入数组a的d个元素:endl; for(pa=a;paa+d;pa++) cin*pa; cout输入数组b中元素的个数:endl; cine; cout输入数组b的e个元素:e
显示全部
相似文档