头歌——c++单向链表

#include <iostream>  
using namespace std;
struct Linked
{
    /********* Begin *********/
    //结构体的成员变量  
    int num;
    float score;
    Linked* next;
    /********* End *********/
};
Linked* Create()
{
    /********* Begin *********/
    //创建并返回一个新链表  
    Linked* head = new Linked;
    head->next = 0; //初始化为0  
    return head;
    /********* End *********/
}
void InsertAfter(Linked* node, int num, float sc)
{
    /********* Begin *********/
    //在指定节点后插入一个新节点,内容由 num,sc 参数指定  
    Linked* n = new Linked;
    n->num = num;
    n->score = sc;
    n->next = node->next;
    node->next = n;
    /********* End *********/
}
void DeleteAfter(Linked* node)
{
    /********* Begin *********/
    //删除此节点之后的一个节点  
    node->next = node->next->next;
    /********* End *********/
}
Linked* GetByIndex(Linked* head, int index)
{
    /********* Begin *********/
    //返回指定索引处的节点  
    Linked* ptr = head->next;
    while (index)
    {
        ptr = ptr->next;
        index--;
    }
    return ptr;
    /********* End *********/
}
void PrintAll(Linked* head)
{
    /********* Begin *********/
    //按格式打印此链表中所有节点的成员变量  
    Linked* ptr = head->next;
    while (ptr)
    {
        cout << ptr->num << " " << ptr->score << endl;
        ptr = ptr->next;
    }
    /********* End *********/
}
int main()
{
    int num;
    float score;
    cin >> num >> score;
    Linked* lk = Create();
    InsertAfter(lk, num, score);
    cin >> num >> score;
    InsertAfter(GetByIndex(lk, 0), num, score);
    cin >> num >> score;
    InsertAfter(GetByIndex(lk, 1), num, score);
    DeleteAfter(GetByIndex(lk, 0));
    PrintAll(lk);
}

头歌练习题网址:C&C++ 面向过程编程综合练习 (educoder.net)

  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++课后习题及答案 一、 选择填空 1. 下列各种高级语言中,( )是面向对象的程序设计语言。 A.BASIC; B.PASCAL; C.C++ D.Ada 2. 下列各种高级语言中,( )是最早提出了对象的概念。 A.Algol 60; B.Simula 67; C.Smalltalk; D.C++ 3. 下述面向对象抽象的原理中,( )是不对的。 A. 数据抽象; B. 行为共享; C.进化; D. 兼容; 4. ( )不是面向对象系统所包含的要数。 A. 重载; B. 对象; C. 类; D. 继承; 5. 关于C++与C语言的关系的描述中,( )是错误的。 A. C语言是C++的一个子集; B. C语言与C++是兼容的; C. C++对C语言进行了一些改进; D. C++和C语言都是面向对象的; 6. 下面关于对象概念的描述中,( )是错误的。 A.对象就是C语言中的结构变量; B.对象代表着正在创建的系统中的一个实体; C. 对象是一个状态和操作(或方法)的封装体; D.对象之间的信息传递是通过消息进行的; 7. 下面关于类概念的描述中,( )是错误的。 A.类是抽象数据类型的实现; B.类是具有共同行为的若干对象的统一描述体; C.类是创建对象的样板; D.类就是C语言中的结构类型; 8. C++对C语言作了很多改进,下列描述中( )使得C语言发生了质变,即从面向过程变成为面向对象。 A.增加了一些新的运算符; B.允许函数重载,并允许设置缺省参数; C.规定函数说明必须用原型; D.引进了类和对象的概念; 9. 按照标识符的要求,( )符号不能组成标识符。 A.连接符; B. 下划线; C.大小写字母; D.数字字符; 10. 下列符号中,( )不可作为分隔符。 A.,; B.:;C.?; D.;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值