课程主页在:http://blog.csdn.net/sxhelijian/article/details/11890759
第一部分 程序分析
阅读下面的程序,先写出其运行结果,再运行对比。
读不懂怎么办?支招1:按课堂上老师讲课的方式,将变量对应内存的“框子”画出来,用大脑当CPU,写出变量的变化过程;支招2:单步执行程序,在监视(watch)窗口中观察变量的动态变化,从而掌握程序的运行机理。
(1)
#include <iostream> using namespace std; void prt(int*, int*, int*); int a=10, b=40, c=20; int main() { prt(&a, &b, &c); prt(&a, &b, &c); return 0; } void prt(int *x, int *y, int *z) { cout<<++*x<<','<<++*y<<','<<*(z++)<<'\n'; }
(2)
#include <iostream> using namespace std; int sub(int*); int main() { int i, k; for (i=0; i<4; i++) { k=sub(&i); cout<<"sum="<<k<<'\t'; } cout<<"\n"; return 0; } int sub(int *s) { static int t=0; t=*s + t; return t; }
(3)
#include <iostream> using namespace std; int *p; void pp(int a, int *b); int main() { int a=1, b=2, c=3; p=&b; pp(a+c, &b); cout<<"(2)"<<a<<','<<b<<','<<*p<<endl; return 0; } void pp(int a, int *b) { int c=4; *p=*b+c; a=*p-c; cout<<"(1)"<<a<<','<<*b<<','<<*p<<endl; }
(4)
#include <iostream> using namespace std; static int a[ ]= {1,3,5,7,11,13}; int main( ) { int *p; p=a+3; cout<<*p<<'\t'<<(*p++)<<endl; cout<<*(p-2)<<'\t'<<*(a+4)<<endl; return 0; }
第二部分 上机任务
【项目1-打入“内部”寻“内幕”】下面是一段使用了指针的程序。请利用“单步”执行的方式运行程序,深刻理解“指针变量存储的是地址值”、“通过指针变量间接访问”等概念。将在执行过程中留下深刻映像的界面截屏下来(不限一个),并加以点评。
#include<iostream> using namespace std; int main() { int a=2, b=3, c[5]= {1,2,3,4,5}; int *p1, *p2, *p3; p1=&a; p2=&b; p3=c; p3++; (*p3)+=10; cout<<a<<'\t'<<b<<'\t'<<c[1]<<endl; cout<<*p1<<'\t'<<*p2<<'\t'<<*p3<<endl; return 0; }
通过这个项目,再次强调学会单步调试。挖掘机就在面前,却就要用铁锹一锹一锹挖,这怎么能让人说你勤奋?!单步调试这台挖掘机,只要上手,就能会开,遇到困难,有各种途径。
下面是单步运行中的一张图片,供参考:
【项目2-指来指去】设计一个程序,利用指针完成下面的工作
(1)下面的程序,输入10 100和100 10,均可以输出max=100 min=10,请补充完整程序
#include <iostream> using namespace std; int main( ) { int *p1,*p2,a,b,t; cin>>a>>b; p1=&a; p2=&b; //下面加入代码,只许用p1,p2和t,不许用a和b,t作为交换时的中间变量 cout<<"max="<<a<<" min="<<b<<endl; return 0; }
(2)下面的程序将调用函数进行变量的交换,请设计出交换的函数
#include <iostream> using namespace std; int main( ) { int a,b; cin>>a>>b; jiaohuan(&a,&b); cout<<"交换后:a="<<a<<" b="<<b<<endl; return 0; } //下面定义jiaohuan函数;
【项目3-填空学指针】采用指针访问方式从键盘给数组a[N]输入数据,然后对元素值重新按逆序存放并输出。请补充完整下面的程序。
#include <iostream> using namespace std; const int N=8; int main() { int a[N],*p,*q; for(p=a; p<a+N; p++) ___(1)___; p=a; q=a+N-1; while(p<q) { int r=*p; *p=*q; *q=r; ___(2)___; ___(3)___; } for(p=a; p<a+N; p++) cout<<*p<<' '; cout<<endl; }
【项目4-有相同数字?】编写程序,要判断两个有序数组中是否存在相同的数字
参考代码:
#include<iostream> using namespace std; int main() { int a[]={1,4,7,8}; int b[]={2,5,6,9,10}; int n1=sizeof(a)/sizeof(a[0]); int n2=sizeof(b)/sizeof(b[0]); bool flag=existthesame(a,n1,b,n2); if(flag==true) cout<<"两个有序数组中存在相同的数字!\n"; else cout<<"两个有序数组中不存在相同的数字!\n"; return 0; } bool existthesame(int *a,int n1, int *b,int n2) { }
【项目5-奇数因子】编写函数 int fun(int x, int *pp)。其功能是,求出x的所有奇数因子,并按照从小到大的顺序放在pp指向的内存中,函数返回值为这些整数的个数。若x的值为30,数组中的数为1,3,5,15,函数返回4。
下面是该程序main()函数的部分代码作为参考。
int main() { int a[50],x,n; ____________; n=fun(x,a); cout<<x<<”的奇因子共有”<<n<<”个,分别是:” for(int i=0;i<n;i++) _________________; cout<<endl; ______________; return 0; } //下面定义fun函数
==================== 迂者 贺利坚 CSDN博客专栏=================
|== IT学子成长指导专栏 专栏文章分类目录(不定期更新) ==|
|== C++ 课堂在线专栏 贺利坚课程教学链接(分课程年级) ==|
======== 为IT菜鸟起飞铺跑道,和学生一起享受快乐和激情的大学 =======