zoukankan      html  css  js  c++  java
  • 6-1 顺序表创建和就地逆置 (10 分)

    本题要求实现顺序表的创建和就地逆置操作函数。L是一个顺序表,函数ListCreate_Sq(SqList &L)用于创建一个顺序表,函数ListReverse_Sq(SqList &L)是在不引入辅助数组的前提下将顺序表中的元素进行逆置,如原顺序表元素依次为1,2,3,4,则逆置后为4,3,2,1。

    函数接口定义:

    Status ListCreate_Sq(SqList &L);
    void ListReverse_Sq(SqList &L);
    

      

    裁判测试程序样例:

    //库函数头文件包含
    #include<stdio.h>
    #include<malloc.h>
    #include<stdlib.h>
    
    //函数状态码定义
    #define TRUE        1
    #define FALSE       0
    #define OK          1
    #define ERROR       0
    #define INFEASIBLE -1
    #define OVERFLOW   -2
    
    typedef int  Status;
    
    //顺序表的存储结构定义
    #define LIST_INIT_SIZE  100
    #define LISTINCREMENT   10
    typedef int ElemType;  //假设线性表中的元素均为整型
    typedef struct{
        ElemType* elem;   //存储空间基地址
        int length;       //表中元素的个数
        int listsize;     //表容量大小
    }SqList;    //顺序表类型定义
    
    Status ListCreate_Sq(SqList &L);
    void ListReverse_Sq(SqList &L);
    
    int main() {
        SqList L;
        ElemType *p;
    
        if(ListCreate_Sq(L)!= OK) {
            printf("ListCreate_Sq: 创建失败!!!
    ");
            return -1;
        }
    
        ListReverse_Sq(L);
    
        if(L.length){
    	for(p=L.elem;p<L.elem+L.length-1;++p){
    	    printf("%d ",*p);
    	}
    	printf("%d",*p); 
        }
        return 0;
    }
    /* 请在这里填写答案 */
    

      

    输入格式: 第一行输入一个整数n,表示顺序表中元素个数,接下来n个整数为表元素,中间用空格隔开。 输出格式: 输出逆置后顺序表的各个元素,两个元素之间用空格隔开,最后一个元素后面没有空格。

    输入样例:

    4
    1 2 3 4
    

      

    输出样例:

    4 3 2 1
    

      

    Status ListCreate_Sq(SqList &L)
    {
        L.elem = (ElemType*)malloc(sizeof(ElemType)*(LIST_INIT_SIZE));
        L.length = 0;
        L.listsize = LIST_INIT_SIZE;
    
        int N;
        scanf("%d", &N);
        while(N > L.listsize){
            L.elem = (ElemType*)malloc(sizeof(ElemType)*(L.listsize+LISTINCREMENT));
            L.listsize += LISTINCREMENT;
        }
        if(!L.elem)
             exit(OVERFLOW);
    
        for(int i=0; i<N; ++i){
            scanf("%d", &L.elem[i]);
            L.length++;
        }
            return OK;
    }
    
    void ListReverse_Sq(SqList &L)
    {
        int len = L.length;
        for(int i=0; i<len/2; ++i){
            int temp = L.elem[i];
            L.elem[i] = L.elem[len-1-i];
            L.elem[len-1-i] = temp;
        }
    }
    

      

     

  • 相关阅读:
    Leetcode Minimum Path Sum
    Leetcode House Robber II
    洛谷 P5375 【[THUPC2019]组合数据结构问题】题解
    洛谷 P1855 【榨取kkksc03】题解
    CF1173A 【Nauuo and Votes】题解
    [NOIP2018D1T1][NOIP2013D1T1][Luogu P5019]铺设道路 题解
    [BZOJ1083][SCOI2005]繁忙的都市 题解
    统计自己洛谷AC题目爬虫
    CF43A Football 题解
    SP2 PRIME1
  • 原文地址:https://www.cnblogs.com/Jie-Fei/p/9648787.html
Copyright © 2011-2022 走看看