Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 20.12.2021
Сообщений: 23
1

Избавиться от strlen

28.04.2022, 21:18. Показов 754. Ответов 3

Author24 — интернет-сервис помощи студентам
C Скопировано
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
 
char delete_spaces(char str1[], char str2[]);
int count(char str2[]);
void output(char srt2[]);
 
int main() {
    int res;
    char str1[100];
    char str2[100];
    gets_s(str1, 99);
    puts(str1);
    str2[99] = delete_spaces(str1, str2);
    res = count(str2);
    output(str2);
    return 0;
}
 
char delete_spaces(char str1[], char str2[]) {
    int i;
    int j = 0;
    for (i = 0, j = 0; i < strlen(str1);i++) {
        if (str1[i] == ' ') {
            while (str1[i] == ' ') {
                str1[i] = str1[i + 1];
                i++;
            }
            str2[j] = str1[i];
            j++;
        }
 
        else {
            while (str1[i] != ' ') {
                str2[j] = str1[i];
                i++;
                j++;
 
            }
            str2[j] = ' ';
            j++;
        }
    }
    for (j = 0;j < strlen(str2);j++) {
        putchar(str2[j]);
    }
    return str2;
}
 
 
 
 
int count(char str2[]) {
    int res = 0;
    for (int j = 0;j < strlen(str2);j++) {
        if (str2[j] == ' ') {
            res++;
        }
    }
    res++;
    printf("\n");
    printf("Count of words: %d\n", res);
}
 
void output(char str2[]) {
    int first, last;
    char word[30], temp[30];
    int flag = 1;
    int i;
    for (i = 0; str2[i] != '.'; i++) {
        first = i;
 
        while (str2[i] != ' ' && str2[i] != '.')
        {
            word[i] = str2[i];
            i++;
        }
        last = i;
        if (flag) {
            for (int j = first; j < last; j++) {
                putchar(word[j]);
            }
            printf(" ");
 
            flag = !flag;
        }
        else {
            for (int l = (last - 1); l >= first; l--) {
                putchar(word[l]);
            }
            flag = !flag;
            printf(" ");
        }
    }
 
}
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
28.04.2022, 21:18
Ответы с готовыми решениями:

Почему в коде записано strlen()+1 вместо strlen()
здравствуйте. объясните пожалуйста. почему для выделения места на основе размера уже существующей строки используется значение...

strlen
Есть ли подобие strlen, но для других типов данных? int*, short* и тп?

strlen()+1
Зачем использовать strlen в данном случае? char s; get.cin(s,strlen(s)+1);

3
 Аватар для programmer_08
687 / 444 / 209
Регистрация: 18.10.2020
Сообщений: 1,606
30.04.2022, 20:59 2
Лучший ответ Сообщение было отмечено svyatexe как решение

Решение

вместо
C Скопировано
1
 i<strlen()
пишите
C Скопировано
1
str1[i]!='\0'
или вот вам функция:
C Скопировано
1
2
3
4
5
6
7
8
int getlen(char* tmp)
{
if(tmp==NULL)
return -1;
int i=0;
for(;tmp[i]!='\0';i++);
return i;
}
и если у вас не меняется строка, то можно вызывать функцию не на каждом шаге цикла при проверке
C Скопировано
1
i<len()
, а задать переменную
C Скопировано
1
2
len1 = len();
 for(int i = 0;i<len1;i++);
и использовать уже её:
C Скопировано
1
 i<len1
2
из племени тумба-юбма
 Аватар для мама Стифлера
2492 / 1814 / 418
Регистрация: 29.11.2015
Сообщений: 8,810
Записей в блоге: 15
30.04.2022, 23:46 3
Цитата Сообщение от programmer_08 Посмотреть сообщение
C Скопировано
3
4
if(tmp==NULL)
return -1;
Такое условие обязательно нужно? Ведь вроде если нулевая строка, так и вернет i=0
0
 Аватар для programmer_08
687 / 444 / 209
Регистрация: 18.10.2020
Сообщений: 1,606
30.04.2022, 23:49 4
мама Стифлера, ну null - это значит, что строки нет и тогда возврат -1.
но при этом строка может существовать и быть пустой и именно тогда нужно возвращать 0
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
30.04.2022, 23:49
Помогаю со студенческими работами здесь

ф-я strlen()
&lt;?include 'C:\Ampps\www\copy_my_test\core\init.php';?&gt; &lt;?php if (!empty($_POST)) { $required_fields = array('login', 'password',...

strlen
добрый вечер. пытаюсь придумать менее затратный strlen) вопрос появился: максимальный размер строки без выделения в куче и с выделением...

strlen
Или я дурак,или лыжи не едут??? Люди добрые, скажите чего не так. Не могу определить длину строки. Хоть вручную считай... вот код int...

функция strlen
#include &quot;stdafx.h&quot; #include &lt;stdio.h&gt; #include &lt;conio.h&gt; #include &lt;string.h&gt; #define maxline 1000 // for s #define eof -1...

Вариант strlen()
Я недавно начал заниматься программированием и на днях решил сделать аналог strlen(), так как это было домашним заданием в моём...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему

Редактор формул (кликните на картинку в правом углу, чтобы закрыть)
Новые блоги и статьи
Вопросы на собеседовании по Android
mobDevWorks 14.03.2025
По данным статистики, Android занимает более 70% мирового рынка мобильных операционных систем, что делает платформу привлекательной как для начинающих разработчиков, так и для опытных профессионалов. . . .
Лучшие игровые движки для Python
py-thonny 14.03.2025
Python обеспечивает разработчиков игр мощными движками и фреймворками, которые позволяют воплотить практически любую идею — от простой аркады до визуального романа с разветвленным сюжетом. Главное. . .
Бессерверный JavaScript: Разработка масштабируемых API с AWS Lambda
run.dev 14.03.2025
Но что такое бессерверные вычисления на самом деле? По сути, это модель облачных вычислений, где разработчик фокусируется исключительно на создании бизнес-логики, не тратя время на настройку. . .
Безопасность кода в C++26: Менеджеры ресурсов и висячие ссылки
NullReferenced 14.03.2025
C++ всегда был языком, предоставляющим разработчикам большие возможности и гибкость, но вместе с тем требующим ответственности. Одной из самых коварных проблем даже для опытных программистов остаются. . .
smart-agent proper interface settings (2025)
jigi33 14.03.2025
Smart-agent proper interface settings (mart 2025). (see screenshots to look at "Etalon" ARM)
Продвинутые настройки JVM
Javaican 14.03.2025
Стандартные параметры запуска JVM хороши для повседневной разработки, но совершенно недостаточны для высоконагруженных систем. Представьте, что вы запускаете финансовую платформу, обрабатывающую. . .
CI/CD для приложений Java с Azure DevOps и Docker
Mr. Docker 14.03.2025
Разработка современных Java-приложений немыслима без системы непрерывной интеграции и доставки (CI/ CD). Azure DevOps в сочетании с Docker предоставляет мощный инструментарий для создания таких. . .
Разработка на PHP и интернет вещей (IoT)
Jason-Webb 14.03.2025
Интернет вещей (IoT) произвел настоящую революцию в способах взаимодействия устройств с окружающим миром. В эпоху, когда холодильники сами заказывают молоко, а термостаты учатся вашим привычкам,. . .
Node.js 20: Новые возможности и улучшения производительно­сти
Reangularity 14.03.2025
Что же принёс нам релиз Node. js 20? В первую очередь, это существенные улучшения в производительности. Движок V8 получил серьёзные оптимизации, благодаря чему JavaScript-код выполняется заметно. . .
Безопасность кластеров Apache Kafka
Javaican 14.03.2025
Apache Kafka стал одним из ключевых компонентов современных архитектур, обрабатывающих потоки данных в режиме реального времени. Его используют тысячи компаний от стартапов до технологических. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер