用链表或者指针数组,输入5个字符串,对字符串排序并输出

Posted zhaohuan1996

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用链表或者指针数组,输入5个字符串,对字符串排序并输出相关的知识,希望对你有一定的参考价值。

#include<stdio.h>
#include<malloc.h>
#include<string.h>
#include<stdlib.h>
#include<math.h>
#include<string.h>
#include <iostream>
typedef struct node{
    char data[100];
    struct node *next;
}LinkList;
/*尾插法创建链表*/
void CreateR(LinkList *&L){
    int i;
    char str[5][100];
    LinkList *r,*s;
    L = (LinkList*)malloc(sizeof(LinkList));
    r=L;
    for(i=0;i<5;i++){
        s = (LinkList*)malloc(sizeof(LinkList));
        strcpy(s->data,gets(str[i]));
        r->next = s;
        r = s;
    }
    r->next = NULL;
}
/*插入排序*/
void Sort(LinkList *&L){
    LinkList *p=L->next->next,*pre,*s;
    L->next->next = NULL;
    while(p!=NULL){
        s=p->next;
        p->next=NULL;
        pre=L;
        while(pre->next!=NULL&&strcmp(pre->next->data,p->data)<0){
            pre=pre->next;
        }
        p->next=pre->next;
        pre->next=p;
        p=s;
    }
}
int main()
{
    LinkList *L,*S;
    CreateR(L);
    for(S=L;S!=NULL;S=S->next){
        printf("%s ",S->data);
    }
    printf("
");
    Sort(L);
    for(S=L;S!=NULL;S=S->next){
        printf("%s ",S->data);
    }
    return 0;
}

 

#include<stdio.h>
#include<malloc.h>
#include<string.h>
#include<stdlib.h>
#include<math.h>
#include<string.h>
#include <iostream>
int main()
{
    char s[5][100],*p[5],*t;
    int n=5,i,j,k;
    for(i=0;i<n;i++){
        gets(s[i]);
        p[i]= s[i];
    }
    for(i=0;i<n-1;i++){
        k=i;
        for(j=i+1;j<n;j++){
            if(strcmp(p[k],p[j])>0){
                k=j;
            }
        }
        if(k!=i){
            t=p[i];
            p[i]=p[k];
            p[k]=t;
        }
    }
    for(i=0;i<n;i++){
        printf("%s ",p[i]);
    }
    return 0;
}

 

#include<stdio.h>
#include<malloc.h>
#include<string.h>
#include<stdlib.h>
#include<math.h>
#include<string.h>
#include <iostream>
int main()
{
    char s[5][100],temp[100];
    int n=5,i,j,k;
    for(i=0;i<n;i++){
        gets(s[i]);
    }
    for(i=0;i<n-1;i++){
        for(j=0;j<n-i-1;j++){
            if(strcmp(s[j],s[j+1])>0){
                strcpy(temp,s[j]);
                strcpy(s[j],s[j+1]);
                strcpy(s[j+1],temp);
            }
        }
    }
    for(i=0;i<n;i++){
        printf("%s ",s[i]);
    }
    return 0;
}

 

以上是关于用链表或者指针数组,输入5个字符串,对字符串排序并输出的主要内容,如果未能解决你的问题,请参考以下文章

ZZNUOJ_用C语言编写程序实现1177:字符串排序(指针专题)(附完整源码)

2021.5.29 链表

c语言指针数组排序?

148. 排序链表

表插入排序算法

树的实现与应用:1.给定一棵用链表表示的二叉树,其根指针为root,试写出求二叉树结点数目。