指针填空

/*
* 程序的版权和版本声明部分
* Copyright (c)2012, 烟台大学计算机学院学生
* All rightsreserved.
* 文件名称: fun.cpp
* 作 者:王飞
* 完成日期:2013 年 4月 5日
* 版本号: v1.0
* 对任务及求解方法的描述部分:指针填空
* 输入描述:略
* 问题描述:略
* 程序输出:如下
*/

// 用指针访问对象
#include<iostream>
using namespace std;
class A {
private:
    int a;
public:
    A() {a=0;}
    A(int aa):a(aa){}           //定义构造函数,用参数aa初始化数据成员a
    void print();
};

void A::print()
{
    cout<<a<<endl;
}

int main() {
    A *p;                      //定义类A的指针对象p
    p=new A(456);             //用p指向动态对象并初始化为整数
    p->print();

   return 0;
}



输出结果:

心得体会:

通过new来开辟动态的空间,再通过指针进行访问,练习应用!

### C语言指针练习题 #### 题目描述 给定一段代码,分析并预测其执行结果。 ```c #include <stdio.h> int main() { char* c[] = {"ENTER", "NEW", "POINT", "FIRST"}; char** cp[] = {c + 3, c + 2, c + 1, c}; char*** cpp = cp; printf("%s\n", **++cpp); printf("%s\n", *--*++cpp + 3); printf("%s\n", *cpp[-2] + 3); printf("%s\n", cpp[-1][-1] + 1); return 0; } ``` #### 输出解析 对于上述代码片段中的输出语句逐一解释: - `printf("%s\n", **++cpp)` 将打印 `"NEW"`。`cpp` 初始指向 `cp[0]` 即 `c+3` 或者说数组 `c` 的第四个元素 `"FIRST"`;`++cpp` 后指向 `cp[1]`,即 `c+2` 或者说是第三个字符串 `"POINT"`;再通过解引用操作符得到该位置存储的内容地址进而访问到对应的字符串 `"NEW"`[^1]。 - 对于 `printf("%s\n", *--*++cpp + 3)` 来讲,在此之前 `cpp` 已经被更新为指向 `cp[1]`,因此 `++cpp` 让它前进至 `cp[2]` 并再次减一回到 `cp[1]`,此时表达式的前半部分相当于获取到了 `"POINT"` 字符串的位置,再加上偏移量 `3` 得到最后三个字母 `"INT"`。 - 接下来一条指令 `printf("%s\n", *cpp[-2] + 3)` 中 `-2` 表明相对于当前 `cpp` 所指示的地方向前移动两个单位到达 `cp[0]` 处也就是 `"FIRST"` 这个字符串,并加上索引位移 `3` 显示出剩余的部分 `"ST"`。 - 最终一句 `printf("%s\n", cpp[-1][-1] + 1)` 可分解成先定位到 `cp[0]` (`cpp - 1`) 然后再取其中最后一个成员所代表的字符串 `"FIRST"` 加上一个字符长度从而显示出从第二个字符开始截断后的子串 `"IRST"`。 综上所述,完整的输出应如下所示: ``` NEW INT ST IRST ``` #### 关键概念复习 为了更好地理解这类题目,建议掌握以下几个方面知识点: - 数组名作为指针使用时的行为特性; - 如何利用多级间接寻址来处理复杂的数据结构; - 深入了解运算符优先级以及它们如何影响最终计算的结果。 #### 示例填空题 考虑以下函数用于在一个字符串中查找特定字符首次出现的位置: ```c char* find_char(char const *str, char const *chars) { char *cp; if(str != NULL && chars != NULL) { for (; *str != '\0'; str++) { for (cp = chars; *cp != '\0'; cp++) { if(*str == *cp) ________; // 应填写什么? } } } return NULL; } ``` 正确答案应该是 `return str` 当匹配成功时立即返回当前指针位置表示找到了目标字符所在处[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值