C语言程序设计(王立柱)第四章答案 顺序表

简介: 只有聪明人才能看见的摘要~( ̄▽ ̄~)~

  两题写在一起了,注意既然是使用顺序表就应该使用顺序表的方法实现,而不是直接访问数据。

在逆置函数换位的时候需要注意的问题已经写在函数里面的注释里了。

还有,我看书的时候一直很奇怪为什么在头文件里使用Type前并没有typedef () Type,然后我写的时候,不使用typedef会报错,但是写完后,在源文件里使用typedef int Type实例化后,本来担心两次typedef int Type会不会有错误,但是这时删掉头文件的typedef int Type已经不报错了

//seqlist.h
#pragma once
#include<stdio.h>
#include<stdlib.h>
typedef struct SeqList
{
  Type* data;
  int max;
  int size;
}List;
void InitSeqList(List* l, int n);
//构造函数,建立空顺序表
void FreeSeqList(List* l) { free(l->data); }
//析构函数
void Reserve(List* l, int newmax);
//扩大数组长度
void Insert(List* l, int id, Type item);
//定点插入
void PushFront(List* l, Type item) { Insert(l, 0, item); }
//首插
void PushBack(List* l, Type item) { Insert(l, l->size, item); }
//尾插
void Erase(List* l, int id);
//定点删除
void PopBack(List* l) { Erase(l, l->size - 1); }
//尾删
void PopFront(List* l) { Erase(l, 0); }
//首删
void Clear(List* l) { l->size = 0; }
//清表
int GetSize(const List* l) { return l->size; }
//读取数据个数
Type GetData(const List* l, int id) { return l->data[id]; }
//读取索引为id的数据
void InitSeqList(List* l, int n)
{
  l->data = (Type*)malloc(n * sizeof(Type));
  if (l->data == 0)
  {
    printf("allocation failure!\n");
    exit(1);
  }
  l->max = n;
  l->size = 0;
}
void Reserve(List* l, int newmax)
{
  int i;
  Type* old;
  if (newmax < l->max)
    return;
  old = l->data;
  l->max = newmax;
  l->data = (Type*)malloc(newmax * sizeof(Type));
  for (i = 0; i < l->max; i++)
    l->data[i] = old[i];
  free(old);
}
void Insert(List* l, int id, Type item)
{
  int i;
  if (id<0 || id>l->size)
  {
    printf("Insert:id is illegal!");
    exit(1);
  }
  if (l->size == l->max)
    Reserve(l, 2 * l->max);
  for (i = l->size; i > id; i--)
    l->data[i] = l->data[i - 1];
  l->data[id] = item;
  l->size++;
}
void Erase(List* l, int id)
{
  int i;
  if (id<0 || id>l->size - 1)
  {
    printf("Erase:id is illegal!");
    exit(1);
  }
  for (i = id + 1; i < l->size; i++)
    l->data[i - 1] = l->data[i];
  l->size--;
}
//main.c
#include<stdio.h> 
typedef int Type;
#include"seqlist.h"
void OutputArray_list(const List* l);
void Selection_list(List* l);
void Invert_list(List* l);
int main() {
  int n_size;
  int i;
  List seqlist;
  printf("Enter the size of array:\n");
  scanf_s("%d", &n_size);
  InitSeqList(&seqlist, n_size);
  printf("Enter %d integers:\n", n_size);
  for (i = 0; i < n_size; i++)
  {
    int temp;
    scanf_s("%d", &temp);
    Insert(&seqlist, i, temp);
  }
  printf("选择排序结果:\n");
  Selection_list(&seqlist);
  OutputArray_list(&seqlist);
  printf("逆置结果:\n");
  Invert_list(&seqlist);
  OutputArray_list(&seqlist);
  return 0;
}
void OutputArray_list(const List* l)
{
  int n = GetSize(l);
  int i;
  for (int i = 0; i < n; i++)
    printf("%d\t", GetData(l, i));
  printf("\n");
}
void Selection_list(List* l)
{
  int n = GetSize(l);
  while (n > 1)
  {
    int max = 0;//选择排序最大值的索引
    for (int i = 1; i < n; i++)
    {
      if (GetData(l, max) < GetData(l, i))
        max = i;
    }
    int item = GetData(l, max);//要删除再重新插入的最大值
    Erase(l, max);//定点删除
    Insert(l, n - 1, item);//定点插入到无序顺序表的最后一个
    n--;
  }
}
void Invert_list(List* l)
{
  int n = GetSize(l);
  int left = 0;
  int right = n - 1;
  int temp;
  for (; left < right; left++, right--)
  {
    temp = GetData(l, left);
    Erase(l, left);
    //删除后数据前移一位,size-1
    Insert(l, left, GetData(l, right - 1));
    //第一次换位,虽然数据前移了但是right和right-1的值相等,结果是正确的
    //但是第一次换位后,第二次的删除操作使right前移一位
    //如果没有减一就会导致实际上的right(第二次操作移到left的值)是right+1
    //去掉减一运行观察一下就懂了
    Erase(l, right);
    Insert(l, right, temp);
  }
}

image.gif


目录
相关文章
|
7天前
|
存储 C语言
【C语言程序设计——函数】递归求斐波那契数列的前n项(头歌实践教学平台习题)【合集】
本关任务是编写递归函数求斐波那契数列的前n项。主要内容包括: 1. **递归的概念**:递归是一种函数直接或间接调用自身的编程技巧,通过“俄罗斯套娃”的方式解决问题。 2. **边界条件的确定**:边界条件是递归停止的条件,确保递归不会无限进行。例如,计算阶乘时,当n为0或1时返回1。 3. **循环控制与跳转语句**:介绍`for`、`while`循环及`break`、`continue`语句的使用方法。 编程要求是在右侧编辑器Begin--End之间补充代码,测试输入分别为3和5,预期输出为斐波那契数列的前几项。通关代码已给出,需确保正确实现递归逻辑并处理好边界条件,以避免栈溢出或结果
46 16
|
11天前
|
算法 C语言
【C语言程序设计——循环程序设计】求解最大公约数(头歌实践教学平台习题)【合集】
采用欧几里得算法(EuclideanAlgorithm)求解两个正整数的最大公约数。的最大公约数,然后检查最大公约数是否大于1。如果是,就返回1,表示。根据提示,在右侧编辑器Begin--End之间的区域内补充必要的代码。作为新的参数传递进去。这个递归过程会不断进行,直到。有除1以外的公约数;变为0,此时就找到了最大公约数。开始你的任务吧,祝你成功!是否为0,如果是,那么。就是最大公约数,直接返回。
65 18
|
11天前
|
Serverless C语言
【C语言程序设计——循环程序设计】利用循环求数值 x 的平方根(头歌实践教学平台习题)【合集】
根据提示在右侧编辑器Begin--End之间的区域内补充必要的代码,求解出数值x的平方根;运用迭代公式,编写一个循环程序,求解出数值x的平方根。注意:不能直接用平方根公式/函数求解本题!开始你的任务吧,祝你成功!​ 相关知识 求平方根的迭代公式 绝对值函数fabs() 循环语句 一、求平方根的迭代公式 1.原理 在C语言中,求一个数的平方根可以使用牛顿迭代法。对于方程(为要求平方根的数),设是的第n次近似值,牛顿迭代公式为。 其基本思想是从一个初始近似值开始,通过不断迭代这个公式,使得越来越接近。
42 18
|
11天前
|
C语言
【C语言程序设计——循环程序设计】统计海军鸣放礼炮声数量(头歌实践教学平台习题)【合集】
有A、B、C三艘军舰同时开始鸣放礼炮各21响。已知A舰每隔5秒1次,B舰每隔6秒放1次,C舰每隔7秒放1次。编程计算观众总共听到几次礼炮声。根据提示,在右侧编辑器Begin--End之间的区域内补充必要的代码。开始你的任务吧,祝你成功!
43 13
|
6天前
|
存储 编译器 C语言
【C语言程序设计——函数】分数数列求和2(头歌实践教学平台习题)【合集】
函数首部:按照 C 语言语法,函数的定义首部表明这是一个自定义函数,函数名为fun,它接收一个整型参数n,用于指定要求阶乘的那个数,并且函数的返回值类型为float(在实际中如果阶乘结果数值较大,用float可能会有精度损失,也可以考虑使用double等更合适的数据类型,这里以float为例)。例如:// 函数体代码将放在这里函数体内部变量定义:在函数体中,首先需要定义一些变量来辅助完成阶乘的计算。比如需要定义一个变量(通常为float或double类型,这里假设用float。
19 3
|
11天前
|
存储 安全 C语言
【C语言程序设计——选择结构程序设计】预测你的身高(头歌实践教学平台习题)【合集】
分支的语句,这可能不是预期的行为,这种现象被称为“case穿透”,在某些特定情况下可以利用这一特性来简化代码,但在大多数情况下,需要谨慎使用。编写一个程序,该程序需输入个人数据,进而预测其成年后的身高。根据提示,在右侧编辑器补充代码,计算并输出最终预测的身高。分支下的语句,提示用户输入无效。常量的值必须是唯一的,且在同一个。语句的作用至关重要,如果遗漏。开始你的任务吧,祝你成功!,程序将会继续执行下一个。常量都不匹配,就会执行。来确保程序的正确性。
36 10
|
11天前
|
小程序 C语言
【C语言程序设计——基础】顺序结构程序设计(头歌实践教学平台习题)【合集】
目录 任务描述 相关知识 编程要求 测试说明 我的通关代码: 测试结果: 任务描述 相关知识 编程编写一个程序,从键盘输入3个变量的值,例如a=5,b=6,c=7,然后将3个变量的值进行交换,使得a=6,b=7,c=5。面积=sqrt(s(s−a)(s−b)(s−c)),s=(a+b+c)/2。使用输入函数获取半径,格式指示符与数据类型一致,实验一下,不一致会如何。根据提示,在右侧编辑器补充代码,计算并输出圆的周长和面积。
31 10
|
6天前
|
存储 算法 安全
【C语言程序设计——函数】分数数列求和1(头歌实践教学平台习题)【合集】
if 语句是最基础的形式,当条件为真时执行其内部的语句块;switch 语句则适用于针对一个表达式的多个固定值进行判断,根据表达式的值与各个 case 后的常量值匹配情况,执行相应 case 分支下的语句,直到遇到 break 语句跳出 switch 结构,若没有匹配值则执行 default 分支(可选)。例如,在判断一个数是否大于 10 的场景中,条件表达式为 “num> 10”,这里的 “num” 是程序中的变量,通过比较其值与 10 的大小关系来确定条件的真假。常量的值必须是唯一的,且在同一个。
11 2
|
11天前
|
存储 C语言
【C语言程序设计——循环程序设计】利用数列的累加和求 sinx(头歌实践教学平台习题)【合集】
项的累加和,一般会使用循环结构,在每次循环中计算出当前项的值(可能基于通项公式或者递推关系),然后累加到一个用于存储累加和的变量中。在C语言中推导数列中的某一项,通常需要依据数列给定的通项公式或者前后项之间的递推关系来实现。例如,对于一个简单的等差数列,其通项公式为。的级数,其每一项之间存在特定的递推关系(后项的分子是其前项的分子乘上。,计算sinx的值,直到最后一项的绝对值小于。为项数),就可以通过代码来计算出指定项的值。对于更复杂的数列,像题目中涉及的用于近似计算。开始你的任务吧,祝你成功!
29 6
|
10天前
|
存储 编译器 C语言
【C语言程序设计——函数】回文数判定(头歌实践教学平台习题)【合集】
算术运算于 C 语言仿若精密 “齿轮组”,驱动着数值处理流程。编写函数求区间[100,500]中所有的回文数,要求每行打印10个数。根据提示在右侧编辑器Begin--End之间的区域内补充必要的代码。如果操作数是浮点数,在 C 语言中是不允许直接进行。的结果是 -1,因为 -7 除以 3 商为 -2,余数为 -1;注意:每一个数据输出格式为 printf("%4d", i);的结果是 1,因为 7 除以 -3 商为 -2,余数为 1。取余运算要求两个操作数必须是整数类型,包括。开始你的任务吧,祝你成功!
41 1

热门文章

最新文章