cplus第六版第十一章第十一题稀有可行版本

本文介绍了一个C语言程序,它包含pro函数和四个子函数p1到p4,主要涉及字符串的读取、交换和排序。通过字符处理和输入验证,实现了一种简单的字符操作和字符串管理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<ctype.h>

#define SIZE 11
#define LIM 101

void pro(char (*a)[LIM]);
void p1(char (*a)[LIM]);
void p2(char (*a)[LIM]);
void p3(char (*a)[LIM]);
void p4(char (*a)[LIM]);

int main()

     char a[SIZE][LIM];
     for (int i = 0; i < 10; i++)
         fgets(a[i], 101, stdin);
    
    pro(a);
    
    return 0;
}

void pro(char (*a)[LIM])
{
    char ch;
    
    printf("1 2 3 4 5\n");
        while ((ch = getchar()) != '5')
    {
        if (ch == '\n')
            continue;
        switch(ch)
        {
            case '1':
                p1(a);
                break;
            case '2':
                p2(a);
                break;
            case '3':
                p3(a);
                break;
            case '4':
                p4(a);
                break;
            default:
                printf("1 2 3 4 5\n");
        }
        printf("1 2 3 4 5\n");
    }
}

void p1(char (*a)[LIM])
{
    for (int i = 0; i < 10; i++)
        fputs(a[i], stdout);
}

void p2(char (*a)[LIM])
{
    int top, seek;
    
    for (top = 0; top < 9; top++)
        for (seek = top + 1; seek < 10; seek++)
            if (strcmp(a[top], a[seek]) > 0)
            {
                strcpy(a[10], a[top]);
                strcpy(a[top], a[seek]);
                strcpy(a[seek], a[10]);
            }
    p1(a);
}

void p3(char (*a)[LIM])
{
    char * temp;
    for (int i = 0; i < 9; i++)
        for (int m = i + 1; m < 10; m++)
            if (strlen(a[i]) > strlen(a[m]))
            {
                strcpy(a[10], a[i]);
                strcpy(a[i], a[m]);
                strcpy(a[m], a[10]);
            }
    p1(a);
}

void p4(char (*a)[LIM])
{
    char * temp;
    int q, w, e, r;
    
    q = w = e = r = 0;
    for (int i = 0; i < 9; i++)
        for (int l = i + 1; l < 10; l++)
        {
            while (a[i][e] == ' ')
                e++;
            while (a[i][e] != ' ' && a[i][e] != '\0')
            {
                q++;
                e++;
            }
            while (a[l][r] == ' ')
                r++;
            while (a[l][r] != ' ' && a[l][r] != '\0')
            {
                w++;
                r++;
            }
            if (q > w)
            {
                strcpy(a[10], a[i]);
                strcpy(a[i], a[l]);
                strcpy(a[l], a[10]);
            }
            q = w = e = r = 0;
        }
    p1(a);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

顺安晓迪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值