鱼C论坛

 找回密码
 立即注册
查看: 1030|回复: 9

[已解决]求助一下关于字符串的一道题

[复制链接]
发表于 2020-7-20 15:54:14 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
输入一行字符,统计其中有多少个单词,单词之间用空格隔开
最佳答案
2020-7-24 08:53:57
你这个问题清晰明了。简单高效!统计多少个空格,然后加1就行了。、
可以用变量,初始赋值为1。因为一输入就有一个单词了。至于那些神经病直接回车的,忽略他吧!
让我们来if!:
if(ch==' ')n++;完了!最后printf进行输出打印。当然,你得先定义变量。比如:
char ch;int n=1;
然后啊,一个个地getchar()。
do{
       ch=getchar();
        if (ch==' ') n++;
        }
while((ch==getchar)!='\n');//好久没用过do-while了,不知道后面有没有分号
printf("一共有%d个单词",n);
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-7-20 16:07:55 | 显示全部楼层
print(len(input().split()))
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-20 16:08:27 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-7-20 16:11:26 | 显示全部楼层

这是我在网上看到的一道题scanf不是读到空格就会停止吗这个题用C语言不能实现吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-20 16:44:46 | 显示全部楼层
本帖最后由 永恒的蓝色梦想 于 2020-7-20 16:49 编辑
15533617457 发表于 2020-7-20 16:11
这是我在网上看到的一道题scanf不是读到空格就会停止吗这个题用C语言不能实现吗

#include<iostream>
using namespace std;



int main() {
    ios::sync_with_stdio(false);

    bool prev_is_space = true;
    unsigned count = 0;


    for (;;) {
        switch (cin.get()) {
            case 0:
            case -1:
            case '\r':
            case '\n':
                cout << count << endl;
                return 0;

            case ' ':
                prev_is_space = true;
                break;

            default:
                if (prev_is_space) {
                    ++count;
                }

                prev_is_space = false;
        }
    }
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-20 18:21:13 | 显示全部楼层
本帖最后由 巴巴鲁 于 2020-7-20 18:43 编辑

#include <stdio.h>
int main(void)
{
                char ch;
                int count = 1; // 没有空格1个单词 
                while((ch = getchar()) != '\n')
                {
                        if(ch == ' ')
                        {
                                count++;
                        }
                }
                printf("%d",count);
                return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-24 08:53:57 | 显示全部楼层    本楼为最佳答案   
你这个问题清晰明了。简单高效!统计多少个空格,然后加1就行了。、
可以用变量,初始赋值为1。因为一输入就有一个单词了。至于那些神经病直接回车的,忽略他吧!
让我们来if!:
if(ch==' ')n++;完了!最后printf进行输出打印。当然,你得先定义变量。比如:
char ch;int n=1;
然后啊,一个个地getchar()。
do{
       ch=getchar();
        if (ch==' ') n++;
        }
while((ch==getchar)!='\n');//好久没用过do-while了,不知道后面有没有分号
printf("一共有%d个单词",n);
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-24 10:21:58 | 显示全部楼层
#include <iostream>
using namespace std;

int main(){
        int cnt = 0;
        char ch;
        while(cin.get(ch)){
                if(ch=='\n')break;
                if((ch>='a'&&ch<='z'||ch>='A'&&ch<='Z')&&(cin.peek()==' '||cin.peek()=='\n'))
                        ++cnt;
        }
        cout << cnt;
        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-24 10:28:27 | 显示全部楼层
本帖最后由 baige 于 2020-7-24 10:34 编辑

#include <iostream>
#include <string>
using namespace std;

int main(){
        string text, temp = "";
        getline(cin,text);
        text += ' ';
        int cnt = 0;
        int length = text.size();
        for(int i = 0; i < length; ++i){
                if(text[i]==' '){
                                if(temp.size()==0)
                                        continue;
                        ++cnt;                        
                        cout << cnt << temp << " ";
                        temp = "";
                }
                else {
                        temp += text[i];
                }
        }
        cout << endl << cnt;
        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-28 09:20:09 | 显示全部楼层
首先遍历字符数组,查找空格(strstr,strtok,等函数,或者自己写!),(需要单独处理亦可以使用memmove等函数复制一份子数组)不管有没有,主要难点就是怎么判断它是一个单词!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-13 10:17

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表