Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности
|
|
|
Указатель на массив строк
|
|||
|---|---|---|---|
|
#18+
Доброго времени суток. Прошу помогите мне. Уже излазил все что можно по указателям, массивам в СИ. Не могу решить задачу. Уже не знаю, что делать... нервы на исходе. У меня получилось сделать прогу через стандартные СИшные функции (strtok, strlen и т.д.), но моему преподу это категорически не нравится, не хочет ее принимать. Он требует чтобы все было через указатели (и передача массива и вывод слова из функции). Помоги решить эту проблему Дан массив строк размером MxN (Количество строк и слов в строке определяет пользователь. Найти строку, в которой содержится самое длинное слово. (нахождение слова необходимо сделать в функции) Вывести на экран монитора это слово и номер строки. (вывод должен быть в функции main()) Код: Код: plaintext 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. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.04.2018, 16:47 |
|
||
|
Указатель на массив строк
|
|||
|---|---|---|---|
|
#18+
Пытаюсь передать указатель на массив в функцию... Только прога считывает на 1 строку меньше чем я задал и в количество букв, просто выводит макс. значение char. И я вот без понятия уже как это исправить. Что-то совсем мне указатели не даются. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.04.2018, 21:13 |
|
||
|
Указатель на массив строк
|
|||
|---|---|---|---|
|
#18+
SatanRulez, В Кодблоксе есть отладчик, юз ит, Люк! ptr надо бы менять ptr != " ,.:;" - это не так работает, как ты думаешь ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.04.2018, 22:42 |
|
||
|
Указатель на массив строк
|
|||
|---|---|---|---|
|
#18+
SatanRulez, функция String пытается перебрать все слова, используя разделители " .,:;" и найти из них самое большое? Небольшая несуразица в коде. Если есть время, лучше разобраться, как работают указатели. Судя по коду, нет достаточного понимания процесса. Переменная lenght (длина - leng th ) используется только внутри String, её стоит там и объявить. Не совсем понятно по коду, что должна в результате содержать num_of_string? А ссылки вам в коде можно использовать или именно надо указатели? Можно так же глянуть исходники strtok, strlen и прочих функций, как они работают внутри. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 02.04.2018, 05:32 |
|
||
|
Указатель на массив строк
|
|||
|---|---|---|---|
|
#18+
CEMb, Да, при помощи разделителей " ,.:;" я пытаюсь найти слова (просто я не знаю как это еще сделать, потому что стандартными функциями я не могу пользоваться) Через переменную lenght я хотел в мейне посимвольно вывести самое длинное слово. num_of_string выдает строку в которой находиться самое длинное слово (я ее практически к переменной i привязал, которая в мейне, в цикле for находится) Да, все нужно делать через указатели, Абсолютно все, по другому препод прост не принимает прогу. Код работающей проги, но через стандартные функции: Код: plaintext 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. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 02.04.2018, 13:28 |
|
||
|
Указатель на массив строк
|
|||
|---|---|---|---|
|
#18+
SatanRulezДа, при помощи разделителей " ,.:;" я пытаюсь найти слова (просто я не знаю как это еще сделать, потому что стандартными функциями я не могу пользоваться)посмотри, как работать с указателями, и тебе сразу станет всё понятно, как всё сделать самому, без стандартных функций. char arr[N][M] - это кусок памяти N x M, где хранятся (однобайтовые) символы. char *ptr указывает тоже на кусок памяти. В данном случае, на начало строки. Ты можешь эту память перебирать, в поисках разделителя. Т.е. переписать strtok, но проще char* pch = ptr; - теперь pch тоже указывает на начало строки char ch = *pch; - взять символ, на который указывает pch pch++ - сдинуть указатель на 1 символ (вправо), т.е. на следующий символ. Таким образом, ты можешь перебирать строку и сверять символ ch по очереди со всеми делимитерами(их тоже придётся перебирать или поштучно или в цикле). Это муторно, но так как раз можно хорошо научиться работать с указателями. Свой strlen можно так же написать, перебирать строку до тех пор, пока не встретится нулевой символ. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 03.04.2018, 05:46 |
|
||
|
Указатель на массив строк
|
|||
|---|---|---|---|
|
#18+
CEMbСвой strlen можно так же написать, перебирать строку до тех пор, пока не встретится нулевой символ.Для этой задачи strlen делать не нужно: определить надо (только) номер (индекс) строки, в которой есть "слов самый длинный". ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 03.04.2018, 10:06 |
|
||
|
|

start [/forum/topic.php?fid=57&msg=39623943&tid=2017900]: |
0ms |
get settings: |
9ms |
get forum list: |
11ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
27ms |
get topic data: |
11ms |
get forum data: |
2ms |
get page messages: |
45ms |
get tp. blocked users: |
1ms |
| others: | 14ms |
| total: | 126ms |

| 0 / 0 |
