从excel怎样进入tm1模式

从excel怎样进入tm1模式,第1张

Excel的兼容模式不是可以人工修改的,当你用高版本的程序打开低版本格式文件时,就会自动进入兼容模式,比如用2007或以上版本打开扩展名为.xls的Excel文件时,就会自动进入兼容模式,要取消运陆森兼容模式,你可以把当前文件另存为当前版本的默认格式。兼容模式:当Excel以兼容模式运行时,文件里面旁亩的设置还是按低版本的设置使用,比如最大行悉枝为65536而不是1048576等。

(已修改,请用最新的代码)代码说明:

1级菜单:选择购买的航班号,并显示对应座位状态。

(我只做测试,所以初始化initFlight函数中我只初始了2个航班,需要自己按照我的代码添)

(注意:实际开发软件,链表数据是从数据库中读取的,需要实时同步,如果要多次调用initFlight函数,记得自己写一个释放内存的函数,把所有链表“SINFO和FLINFO”节点都释放掉,释放函数我没写,需要你自己写!!!)

2级菜单:选择购买对应座位号,完成购买,并实时显示购买结果。

位置编号、座位最大排数、舱室类型、折扣等参数均由常量参数空值,需要修改自行改常量。

注意:舱室类型(我默认3个类型头等舱、公务舱、经济舱)对应折扣消和梁参数:tDiscount二维数组。如要如要添加新的舱室类型,必须将参数常量TYPESIZE、typeName、types、tDiscount这4个同时修改,具体看代码备注!!

座位票价=基础票价棚戚*类型折扣*时段折扣。

因为飞机不让吸烟,所以我没做吸烟区(笑),如果你需要,可以作为类型自行添加!

#include<stdio.h>

#include<stdlib.h>

#include<conio.h>

#include<string.h>

#include<malloc.h>

#include<time.h>

//-----------------------相关参数,想改变,在这里修改!!!!!!!-----------------------------

const float timeDiscount=1//时段折扣,影响所有航班最终价格,默认1

const char cID[5]="ABCD"//位置编号

const int maxRow=20//位置最大排号

//注意:如果修改类型数量,types和tDiscount必须同时修改!!!

#define TYPESIZE 3//类型数量

const char typeName[TYPESIZE][10]={"头等舱","公务舱","经济舱"}

const int types[TYPESIZE][2]={{1,2},{3,4},{5,20}}//排号对应类型。1~2排头等舱,3~4排公务舱,5~20排经济舱

const float tDiscount[TYPESIZE]={1.5,1.3,1}//类型折扣。头等舱1.5倍,公务舱1.3倍,经济舱1倍

//-------------------------------------------------------------------------------

typedef struct seatInfo//座位信息,一条链表对应一个航班信息,链表顺序从第一排左边第一个开始往后A1~D1,A2~D2。。。

{

    char cloID//位置编号A、B、C、D

    int row//位置排号

    int type//座位所属类型:0:头等舱、1:公务舱、2:经济舱,不同类型对应不同的类型折扣tDiscount

    int sell//出售状态,0:未出售;1:已出售

    struct seatInfo *next

}SINFO

typedef struct flightInfo//航班信息

{

    char fid[10]//航班号

    time_t tfTime//起飞时间

    time_t 拿运ldTime//降落时间

    char toCity[20]//抵达城市

    float tPrice//基础票价,不同位置具有不同折扣,座位票价=基础票价*类型折扣*时段折扣

    struct flightInfo *next

    struct seatInfo *sHead//对应座位链表的头节点

}FLINFO

void meError(void *p)

SINFO *getSINFO()//获取座位链表

//addFLINFO:添加航班信息链表的节点flinfoHead:头节点(第一次传NULL会自动生成),flinfoTail:尾节点,fNew:要添加的结构信息(成员指针无需赋值)

FLINFO *addFLINFO(FLINFO **ffHead,FLINFO *flinfoTail,FLINFO fNew)//返回尾节点

time_t getTime_tfromStr(char *sTime)//将YYYY-MM-DD hh:mm:ss格式的时间字符串转换成time_t型数值

FLINFO *initFlight()//初始化航班信息,返回航班链表头节点,如果想手动输入,请在这里添加!!!正常软件开发,这一步应该是从数据库读取!

char *getTString(struct tm *tm0)//通过tm获取时间字符串

void showSinfo(FLINFO *flinfo)//显示航班对应座位信息

void printfFlinfo(FLINFO * flinfoHead)

FLINFO *selectFlinfo(FLINFO *flinfoHead,char *fid)//选择航班号,返回节点

void showSinfo(FLINFO *flinfo)//显示航班对应座位信息

SINFO *selectSinfo(FLINFO *flinfo,char *sid)//选择座位,返回节点

int main()

{

    FLINFO *flinfoHead=initFlight(),*ffSelect=NULL

    SINFO *sfSelect=NULL

    char fid[10]={0},sid[10]={10}

    while(1)

    {

        ffSelect=NULL

        sfSelect=NULL

        memset(fid,0,10)

        memset(sid,0,10)

        printfFlinfo(flinfoHead)

        printf("请输入要购买的航班号:")

        scanf("%s",fid)

        ffSelect=selectFlinfo(flinfoHead,fid)

        if(!ffSelect)

        {

            printf("未找到对应航班,按任意键继续-----\n")

            getch()

            system("cls")

            continue

        }

        system("cls")

        printf("航班号:%s 座位信息如下:\n",ffSelect->fid)

        showSinfo(ffSelect)

        printf("请输入要购买的座位编号(输入0返回主菜单):")

        scanf("%s",sid)

        if(!strcmp(sid,"0"))

        {

            system("cls")

            continue

        }

        else

        {

            sfSelect=selectSinfo(ffSelect,sid)

            if(!sfSelect||sfSelect->sell)

            {

                printf("未找到对应座位或该座位已出售,请重新输入!按任意键继续-----\n")

                getch()

                system("cls")

                continue

            }

            printf("购买成功!按任意键继续-----")

            sfSelect->sell=1

            getch()

            system("cls")

        }

    }

    return 0

}

SINFO *selectSinfo(FLINFO *flinfo,char *sid)//选择座位,返回节点

{

    SINFO *sinfoHead=flinfo->sHead

    while(sinfoHead->next)

    {

        if(sinfoHead->next->cloID==sid[0] && sinfoHead->next->row==atoi(sid+1))

            return sinfoHead->next

        sinfoHead=sinfoHead->next

    }

    return NULL

}

void showSinfo(FLINFO *flinfo)//显示航班对应座位信息

{

    SINFO *sinfoHead=flinfo->sHead,*sfp=NULL

    int i,j,k,row=maxRow,clo=strlen(cID)

    char typeStr[10]={0}

    for(i=0i<rowi++)

    {

        //---------读取座位所属舱室------------

        memset(typeStr,0,10)

        for(k=0k<TYPESIZEk++)

            if(i+1>=types[k][0] && i+1<=types[k][1])

                strcpy(typeStr,typeName[k])

        //--------------------------------------

        printf("\n")

        for(j=0j<cloj++)

            printf("------------- ")

        printf("\n")

        sfp=sinfoHead

        for(j=0j<cloj++)

        {

            printf("|    %c%02d    | ",sfp->next->cloID,sfp->next->row)

            sfp=sfp->next

        }

        printf("\n")

        sfp=sinfoHead

        for(j=0j<cloj++)

        {

            printf("|     %c     | ",sfp->next->sell?2:1)

            sfp=sfp->next

        }

        printf("\n")

        sfp=sinfoHead

        for(j=0j<cloj++)

        {

            printf("|%6s:%4.0f| ",typeStr,flinfo->tPrice*tDiscount[sfp->next->type]*timeDiscount)

            sfp=sfp->next

        }

        printf("\n")

        sinfoHead=sfp

    }

    for(j=0i<cloj++)

            printf("------- ")

    printf("\n")

}

FLINFO *selectFlinfo(FLINFO *flinfoHead,char *fid)//选择航班号,返回节点

{

    while(flinfoHead->next)

    {

        if(!strcmp(flinfoHead->next->fid,fid))

            return flinfoHead->next

        flinfoHead=flinfoHead->next

    }

    return NULL

}

void printfFlinfo(FLINFO * flinfoHead)

{

    while(flinfoHead->next)

    {

        printf("目的地:%s,航班号:%s\n----起飞时间:%s,抵达时间:%s\n\n",flinfoHead->next->toCity,flinfoHead->next->fid,getTString(localtime(&flinfoHead->next->tfTime)),getTString(localtime(&flinfoHead->next->ldTime)))

        flinfoHead=flinfoHead->next

    }

}

char *getTString(struct tm *tm0)//通过tm获取时间字符串

{

    char *str=(char *)malloc(sizeof(char)*20),num[5]={0}

    meError(str)

    memset(str,0,20)

    sprintf(num,"%4d",tm0->tm_year+1900)

    strcat(str,num)

    strcat(str,"-")

    memset(num,0,5)

    sprintf(num,"%02d",tm0->tm_mon)

    strcat(str,num)

    strcat(str,"-")

    memset(num,0,5)

    sprintf(num,"%02d",tm0->tm_mday)

    strcat(str,num)

    strcat(str," ")

    memset(num,0,5)

    sprintf(num,"%02d",tm0->tm_hour)

    strcat(str,num)

    strcat(str,":")

    memset(num,0,5)

    sprintf(num,"%02d",tm0->tm_min)

    strcat(str,num)

    strcat(str,":")

    memset(num,0,5)

    sprintf(num,"%02d",tm0->tm_sec)

    strcat(str,num)

    return str

}

time_t getTime_tfromStr(char *sTime)//将YYYY-MM-DD hh:mm:ss格式的时间字符串转换成time_t型数值

{

    time_t rt

    struct tm *tm1=NULL

    rt=time(NULL)

    tm1=localtime(&rt)

    sscanf(sTime,("%4d-%2d-%2d %2d:%2d:%2d"),&tm1->tm_year,&tm1->tm_mon,&tm1->tm_mday,&tm1->tm_hour,&tm1->tm_min,&tm1->tm_sec)

    tm1->tm_year-=1900

    tm1->tm_mon--

    rt=mktime(tm1)

    return rt

}

FLINFO *initFlight()//初始化航班信息,返回航班链表头节点,如果想手动输入,请在这里添加!!!正常软件开发,这一步应该是从数据库读取!

{

    FLINFO *ffHead=NULL,*flinfoTail=NULL,fNew

    //--------添加一个航班信息----需要增加按照我下面调用方式写--------------------------------

    strcpy(fNew.fid,"CI502")

    fNew.tfTime=getTime_tfromStr("2019-02-20 03:30:30")

    fNew.ldTime=getTime_tfromStr("2019-02-20 05:20:30")

    strcpy(fNew.toCity,"台北")

    fNew.tPrice=1000

    fNew.next=NULL

    flinfoTail=addFLINFO(&ffHead,flinfoTail,fNew)

    //--------------------------------------------------------------------------------------------

    strcpy(fNew.fid,"9C8921")

    fNew.tfTime=getTime_tfromStr("2019-02-20 14:30:30")

    fNew.ldTime=getTime_tfromStr("2019-02-20 16:40:30")

    strcpy(fNew.toCity,"香港")

    fNew.tPrice=500

    fNew.next=NULL

    flinfoTail=addFLINFO(&ffHead,flinfoTail,fNew)

    return ffHead

}

FLINFO *addFLINFO(FLINFO **ffHead,FLINFO *flinfoTail,FLINFO fNew)//返回尾节点

//添加航班信息链表的节点flinfoHead:头节点(第一次传NULL会自动生成),flinfoTail:尾节点,fNew:要添加的结构信息(成员指针无需赋值)

{

    FLINFO *flinfoHead=*ffHead

    if(flinfoHead==NULL)

    {

        *ffHead=(FLINFO *)malloc(sizeof(FLINFO))

        flinfoHead=*ffHead

        meError(flinfoHead)

        flinfoHead->next=NULL

    }

    FLINFO *flinfoNew=(FLINFO *)malloc(sizeof(FLINFO))

    meError(flinfoNew)

    flinfoNew->next=NULL

    flinfoNew->fid[0]=0

    strcpy(flinfoNew->fid,fNew.fid)

    flinfoNew->ldTime=fNew.ldTime

    flinfoNew->tfTime=fNew.tfTime

    flinfoNew->toCity[0]=0

    strcpy(flinfoNew->toCity,fNew.toCity)

    flinfoNew->tPrice=fNew.tPrice

    flinfoNew->sHead=getSINFO()

    if(flinfoHead->next==NULL)

        flinfoHead->next=flinfoNew

    else

        flinfoTail->next=flinfoNew

    flinfoTail=flinfoNew

    return flinfoTail

}

SINFO *getSINFO()//获取座位链表

{

    int maxClo=strlen(cID),cnt=maxClo*maxRow,clo=0,row=1,i

    SINFO *sinfoHead=(SINFO *)malloc(sizeof(SINFO)),*sinfoTail=NULL

    meError(sinfoHead)

    sinfoHead->next=NULL

    SINFO *sinfoNew=NULL

    while(cnt--)//按顺序生成对应数量的座位链表

    {

        if(clo==maxClo)

            clo=0,row++

        if(row==maxRow+1)

            row=1

        sinfoNew=(SINFO *)malloc(sizeof(SINFO))

        meError(sinfoNew)

        sinfoNew->cloID=cID[clo]

        sinfoNew->row=row

        for(i=0i<TYPESIZEi++)

            if(row>=types[i][0] && row<=types[i][1])

            {

                sinfoNew->type=i

                break

            }

        sinfoNew->sell=0

        sinfoNew->next=NULL

        if(sinfoHead->next==NULL)

            sinfoHead->next=sinfoNew

        else

            sinfoTail->next=sinfoNew

        sinfoTail=sinfoNew

        clo++

    }

    return sinfoHead

}

void meError(void *p)//内存申请失败

{

    if(p==NULL)

    {

        printf("\n异常:内存申请失败!回车结束程序!\n")

        while(getch()!='\r')

        exit(0)

    }

}

//ping的实好旁现代轿袜碰码

#include <winsock2.h>

#include <ws2tcpip.h>

#include <stdio.h>

#include <stdlib.h>

#define IP_RECORD_ROUTE 0x7

#define DEF_PACKET_SIZE 32

#define MAX_PACKET 1024 // Max ICMP packet size

#define MAX_IP_HDR_SIZE 60// Max IP header size w/options

#define ICMP_ECHO8

#define ICMP_ECHOREPLY 0

#define ICMP_MIN 8 // Minimum 8-byte ICMP packet (header)

typedef struct _iphdr

{

unsigned int h_len:4 // Length of the header

unsigned int version:4 // Version of IP

unsigned char tos // Type of service

unsigned short total_len // Total length of the packet

unsigned short ident // Unique identifier

unsigned short frag_and_flags// Flags

unsigned char ttl // Time to live

unsigned char proto // Protocol (TCP, UDP etc)

unsigned short checksum // IP checksum

unsigned int sourceIP

unsigned int destIP

} IpHeader

typedef struct _icmphdr

{

BYTE i_type

BYTE i_code// Type sub code

USHORT i_cksum

USHORT i_id

USHORT i_seq

//闭谈 This is not the standard header, but we reserve space for time

ULONG timestamp

} IcmpHeader

//

// IP option header - use with socket option IP_OPTIONS

//

typedef struct _ipoptionhdr

{

unsigned charcode // Option type

unsigned charlen// Length of option hdr

unsigned charptr// Offset into options

unsigned longaddr[9]// List of IP addrs

} IpOptionHeader

int parse(int *parc,char *parv[],char* src,int maxpar)

{

int i = 0

char willBeWord

*parc = 0

willBeWord = 1

if(src == NULL)

return 0

while(src[i] != '\0' &&*parc <maxpar)

{

if(src[i] == ' ')

{

willBeWord = 1

src[i] = 0

}

else

{

if((willBeWord >0) &&((src[i] != 0x0D) || (src[i] != 0x0A)))

{

parv[*parc] = &src[i]

(*parc)++

willBeWord = 0

}

}

i++

}

return (*parc)

}

void FillICMPData(char *icmp_data, int datasize)

{

IcmpHeader *icmp_hdr = NULL

char *datapart = NULL

icmp_hdr = (IcmpHeader*)icmp_data

icmp_hdr->i_type = ICMP_ECHO // Request an ICMP echo

icmp_hdr->i_code = 0

icmp_hdr->i_id = (USHORT)GetCurrentProcessId()

icmp_hdr->i_cksum = 0

icmp_hdr->i_seq = 0

datapart = icmp_data + sizeof(IcmpHeader)

}

void DecodeIPOptions(char *buf, int bytes)

{

IpOptionHeader *ipopt = NULL

IN_ADDR inaddr

int i

HOSTENT*host = NULL

ipopt = (IpOptionHeader *)(buf + 20)

//m_dlg->m_result+="Ping 结果: \r\n"

for(i = 0i <(ipopt->ptr / 4) - 1i++)

{

inaddr.S_un.S_addr = ipopt->addr[i]

host = gethostbyaddr((char *)&inaddr.S_un.S_addr,

sizeof(inaddr.S_un.S_addr), AF_INET)

if (host)

{

printf("(%-15s) %s \r\n", inet_ntoa(inaddr), host->h_name)

}

else

{

printf("(%-15s)\r\n", inet_ntoa(inaddr))

}

}

return

}

USHORT checksum(USHORT *buffer, int size)

{

unsigned long cksum=0

while (size >1)

{

cksum += *buffer++

size -= sizeof(USHORT)

}

if (size)

{

cksum += *(UCHAR*)buffer

}

cksum = (cksum >>16) + (cksum &0xffff)

cksum += (cksum >>16)

return (USHORT)(~cksum)

}

void DecodeICMPHeader(char *buf, int bytes, SOCKADDR_IN *from)

{

IpHeader *iphdr = NULL

IcmpHeader *icmphdr = NULL

unsigned short iphdrlen

DWORD tick

static inticmpcount = 0

int tm1

iphdr = (IpHeader *)buf

// Number of 32-bit words * 4 = bytes

iphdrlen = iphdr->h_len * 4

tick = GetTickCount()

if ((iphdrlen == MAX_IP_HDR_SIZE) &&(!icmpcount))

DecodeIPOptions(buf, bytes)

if (bytes <iphdrlen + ICMP_MIN)

{

printf("Too few bytes from %s \r\n",inet_ntoa(from->sin_addr))

}

icmphdr = (IcmpHeader*)(buf + iphdrlen)

if (icmphdr->i_type != ICMP_ECHOREPLY)

{

printf("nonecho type %d recvd \r\n", icmphdr->i_type)

return

}

// Make sure this is an ICMP reply to something we sent!

//

if (icmphdr->i_id != (USHORT)GetCurrentProcessId())

{

printf("someone else's packet! \r\n")

return

}

tm1 = tick - icmphdr->timestamp

if(tm1 <1)

printf("%d bytes from %s: icmp_seq = %d. time: <1ms \r\n", bytes, inet_ntoa(from->sin_addr), icmphdr->i_seq)

else

printf("%d bytes from %s: icmp_seq = %d. time: %d ms \r\n", bytes, inet_ntoa(from->sin_addr), icmphdr->i_seq, tick - icmphdr->timestamp)

icmpcount++

return

}

int main(int argc,char* argv[])

{

WSADATA wsaData

SOCKET m_hSocket

// IpOptionHeader m_ipopt

SOCKADDR_IN m_addrDest

SOCKADDR_IN m_addrFrom

char icmp_data[1024],recvbuf[1024]

USHORT seq_no = 0

char ch, cmdbuf[512],*parv[64],lpdest[64]

int i = 0, parc, nCount = 1

int ct = 0, bwrote, timeout = 1000

int datasize = DEF_PACKET_SIZE

int bread

int fromlen

if (WSAStartup(MAKEWORD(2, 2), &wsaData) != 0)

{

printf("Sorry, you cannot load socket dll!")

return -1

}

/* do{

ch = getchar()

cmdbuf[i++] = ch

}while((ch != 0x0D) &&(ch != 0x0A))

if((cmdbuf[i-1] != ' ') || (cmdbuf[i-1] == 0x0D) || (cmdbuf[i-1] == 0x0A))

{

cmdbuf[i] = cmdbuf[i-1]

cmdbuf[i - 1] = ' '

cmdbuf[i + 1] = '\0'

}

parse(&parc, parv, cmdbuf, sizeof(parv))

if(parc == 0)

return 0

for(i = 1i <parci++)

{

if(strcmp(parv[i],"-t") == 0)

{

nCount = 0

}

else if(strcmp(parv[i],"-n") == 0 &&i <(parc-1))

{

nCount = atoi(parv[i+1])

i++

}

else

{

if(strlen(parv[i]) >6)

{

strcpy(lpdest,parv[i])

}

}

}*/

for(i = 1i <argci++)

{

if(strcmp(argv[i],"-t") == 0)

{

nCount = 0

}

else if(strcmp(argv[i],"-n") == 0 &&i <(argc-1))

{

nCount = atoi(argv[i+1])

i++

}

else

{

if(strlen(argv[i]) >6)

{

strcpy(lpdest,argv[i])

}

}

}

m_hSocket = WSASocket (AF_INET, SOCK_RAW, IPPROTO_ICMP, NULL, 0,

WSA_FLAG_OVERLAPPED)

if (m_hSocket == INVALID_SOCKET)

{

printf("socket 创建失败!")

return -1

}

// Set the send/recv timeout values

//

bread = setsockopt(m_hSocket, SOL_SOCKET, SO_RCVTIMEO,

(char*)&timeout, sizeof(timeout))

if(bread == SOCKET_ERROR)

{

printf("设置socket接收超时选项错误!")

return -1

}

timeout = 1000

bread = setsockopt(m_hSocket, SOL_SOCKET, SO_SNDTIMEO,

(char*)&timeout, sizeof(timeout))

if (bread == SOCKET_ERROR)

{

printf("设置socket发送超时选项错误!")

return -1

}

memset(&m_addrDest, 0, sizeof(m_addrDest))

//

// Resolve the endpoint's name if necessary

//

m_addrDest.sin_family = AF_INET

if ((m_addrDest.sin_addr.s_addr = inet_addr(lpdest)) == INADDR_NONE)

{

struct hostent *hp = NULL

if ((hp = gethostbyname(lpdest)) != NULL)

{

memcpy(&(m_addrDest.sin_addr), hp->h_addr, hp->h_length)

m_addrDest.sin_family = hp->h_addrtype

//printf("m_addrDest.sin_addr = %s\n", inet_ntoa(m_addrDest.sin_addr))

}

else

{

//printf("gethostbyname() failed: %d\n",

// WSAGetLastError())

printf("输入的主机不存在!")

return -1

}

}

//

// Create the ICMP packet

//

datasize += sizeof(IcmpHeader)

//icmp_data =(char*) HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY,

// MAX_PACKET)

//recvbuf =(char*) HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY,

// MAX_PACKET)

//if (!icmp_data)

// {

//AfxMessageBox("堆分配错误!")

// return

//}

memset(icmp_data,0,MAX_PACKET)

FillICMPData(icmp_data,datasize)

//

// Start sending/receiving ICMP packets

//

while(1)

{

if (ct++ >= nCount)

break

((IcmpHeader*)icmp_data)->i_cksum = 0

((IcmpHeader*)icmp_data)->timestamp = GetTickCount()

((IcmpHeader*)icmp_data)->i_seq = seq_no++

((IcmpHeader*)icmp_data)->i_cksum =

checksum((USHORT*)icmp_data, datasize)

bwrote = sendto(m_hSocket, icmp_data, datasize, 0,

(struct sockaddr*)&m_addrDest, sizeof(m_addrDest))

if (bwrote == SOCKET_ERROR)

{

if (WSAGetLastError() == WSAETIMEDOUT)

{

printf("Send timed out ! \r\n")

continue

}

return 0

}

if (bwrote <datasize)

{

printf("Wrote %d bytes \r\n", bwrote)

}

fromlen = sizeof(m_addrFrom)

bread = recvfrom(m_hSocket, recvbuf, MAX_PACKET, 0,

(struct sockaddr*)&m_addrFrom, &fromlen)

if (bread == SOCKET_ERROR)

{

if (WSAGetLastError() == WSAETIMEDOUT)

{

printf("Recv timed out !\r\n")

continue

}

return 0

}

DecodeICMPHeader(recvbuf, bread, &m_addrFrom)

}

if (m_hSocket != INVALID_SOCKET)

closesocket(m_hSocket)

WSACleanup()

return 0

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12387636.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存