7-9 挑单词 (20 分)

该程序用于处理包含英文字符和数字的字符串,找出所有长度大于等于3的连续英文字符序列(单词),并按字母序降序排列。如果未找到符合条件的单词,则输出'noword'。示例输入和输出已给出,程序通过判断字符类型,记录子串起始位置和长度来实现单词提取,并使用了字符串查找和排序功能。
摘要由CSDN通过智能技术生成

挑单词

输入若干行数据,每行只包含英文字符(不区分大小写)和数字字符,请找出所有的“单词”,这里所说的“单词”
指的是长度大于等于3的连续英文字符构成的字符序列,并把找到的“单词”按字母序从大到小排列,若某个单词
重复出现,在结果中只输出一次,若没有满足要求的单词,输出“no word"。

输入格式:
第一行给出总行数n,接下来n行给出由英文字符(不区分大小写)和数字字符组成的串,每行中字符数量不超过
1000,每行以回车结束。

输出格式:
输出“单词”的降序序列,每个“单词”首字母大写,单词间用一个空格分隔,最后一个单词后没有空格。

输入样例1:
在这里给出一组输入。例如:
1
Hi1123hello2how98are2111119you88
输出样例1:
在这里给出相应的输出。例如:

You How Hello Are
输入样例2:
在这里给出一组输入。例如:
2
Fine445thank66you
and990you276w
输出样例2:
在这里给出相应的输出。例如:
You Thank Fine And

输入样例3:
在这里给出一组输入。例如:
2
Fe445ak66
an990u276w
输出样例3:
在这里给出相应的输出。例如:
no word

思路:题目给的字符串只有数字和字母,只要找出连续长度大于3的字串,记录开始下标和结束下标,然后时用substr函数,得到字串,在处理输出。

#include <bits/stdc++.h>
using namespace std;
int main()
{
    int n, index = 0, a = 0, b, c = 0;
    cin >> n;
    getchar();
    string str1, str2[10000], str3, str4 = "";
    while (n--)
    {
        getline(cin, str1);
        a = 0;
        b = 0;
        for (int i = 0; i < str1.length(); i++)
        {

            if ((str1[i] >= 'a' && str1[i] <= 'z') || (str1[i] >= 'A' && str1[i] <= 'Z'))
            {
                if(str1[i] >= 'A' && str1[i] <= 'Z'){
                    str1[i] = 'a' + str1[i] - 'A';
                }//将字符串字符转化为小写,方便后续按照题目要求输出。
                if (!a && !b)//判断开始下标。a是记录子串长度。
                {
                    b = i;
                    a++;
                }
                else
                {
                    a++;
                }
            }
                if (a >= 3 && ((str1[i] >= '0' && str1[i] <= '9') || (i == str1.length() - 1)))
                {
                    str3 = str1.substr(b, a);//通过a,b获取字串
                    if(str4.find(str3) == string::npos){
                        str2[index] = str3;
                        index++;
                        str4 += str3;
                        c = 1;
                    }
                    a = 0;
                    b = 0;
                }
                if (a < 3 && ((str1[i] >= '0' && str1[i] <= '9') || (i == str1.length() - 1)))
                {
                    a = 0;
                    b = 0;
                }
        }
    }
    for(int i = 1; i < index; i++){
        for(int j = 0; j < index - i; j++){
            if(str2[j] < str2[j + 1]){
                str3 = str2[j];
                str2[j] = str2[j + 1];
                str2[j + 1] = str3;
            }
        }
    }
    if(c){
        for(int i = 0; i < index; i++){
            for(int j = 0; j < str2[i].length(); j++){
                if(!j){
                    if ((str2[i][j] >= 'a' && str2[i][j] <= 'z')){
                         printf("%c" , 'A' + str2[i][j] - 'a'); 
                    }else{
                        cout << str2[i][j];
                    }
                }else{
                    cout << str2[i][j];
                }
            }
            if(i != index - 1){
                cout << " ";
            }
        }
    }else{
        cout << "no word";
    }
    return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的C语言程序,用于对从键盘输入的7-11英文单词进行排序: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_WORDS 11 #define MAX_WORD_LENGTH 20 int main(void) { char words[MAX_WORDS][MAX_WORD_LENGTH]; char temp[MAX_WORD_LENGTH]; int i, j; // 从键盘输入单词 printf("请输入 %d 个单词,每个单词长度不得超过 %d 个字符:\n", MAX_WORDS, MAX_WORD_LENGTH - 1); for (i = 0; i < MAX_WORDS; i++) { scanf("%s", words[i]); } // 对单词进行排序 for (i = 0; i < MAX_WORDS - 1; i++) { for (j = i + 1; j < MAX_WORDS; j++) { if (strcmp(words[i], words[j]) > 0) { strcpy(temp, words[i]); strcpy(words[i], words[j]); strcpy(words[j], temp); } } } // 输出排序后的单词 printf("排序后的单词为:\n"); for (i = 0; i < MAX_WORDS; i++) { printf("%s\n", words[i]); } return 0; } ``` 该程序使用了一个二维字符数组 `words` 来存储输入的单词,其中 `MAX_WORDS` 定义了单词的最大数量,`MAX_WORD_LENGTH` 定义了单词的最大长度(包括结尾的空字符)。 程序首先从键盘输入单词并存储到 `words` 数组中,然后使用冒泡排序对单词进行排序,最后输出排序后的单词。注意,在比较单词大小时,使用了 `strcmp()` 函数,该函数可以比较两个字符串的大小,如果第一个字符串小于第二个字符串,则返回一个负数;如果两个字符串相等,则返回0;如果第一个字符大于第二个字符串,则返回一个正数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值