Форум программистов, компьютерный форум CyberForum.ru

Написание функции - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 13, средняя оценка - 4.85
Katrina10
0 / 0 / 0
Регистрация: 31.10.2010
Сообщений: 3
21.02.2011, 21:54     Написание функции #1
Ребята можете пожалуйста помочь с задачей?
Написать функцию, которая возвращает строку, в которой все символы исходной строки отсортированы в алфавитном порядке. Заголовок функции: char * sortChar ( const char * s); Написать программу, которая принимает от пользователя набор строк (массив строк), формирует новый набор строк (массив), где каждый элемент, это строка, состоящая из отсортированных символов соответствующей строки из первого набора и выводит его на экран.
Буду очень Вам благодарна

Добавлено через 2 часа 6 минут
Может кто помочь пожалуйста?((
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
lemegeton
 Аватар для lemegeton
2909 / 1338 / 133
Регистрация: 29.11.2010
Сообщений: 2,720
21.02.2011, 22:25     Написание функции #2
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
#include <stdlib.h>
#include <string.h>
#include <stdio.h>
 
int Compare (const void * a, const void * b) {
  return (*(char*)a - *(char*)b);
}
 
char *SortChar(const char *source) {
  int source_size = strlen(source);
  char *result = strcpy((char*)malloc(source_size + 1), source);
  qsort(result, source_size - 1, sizeof(char), Compare);
  return result;
}
 
int main(int argc, char *argv[]) {
  const int buffer_size = 65536;
  char buffer[buffer_size];
 
  int array_recap = 1024;  // Jedi force
  int array_size = 0;
  int array_capacity = array_recap;
  char **array = (char**)malloc(sizeof(char*) * array_capacity);
 
  int i;  // счетчик
  while (!feof(stdin)) {
    if (fgets(buffer, buffer_size, stdin)) {
      buffer[strlen(buffer) - 1] = '\0'; // удаление переноса строки
      if (array_size == array_capacity) {
        char **new_array = (char**)malloc(sizeof(char*) * (array_capacity += array_recap));
        for (i = 0; i < array_size; ++i) new_array[i] = array[i];
        free(array);
        array = new_array;
      }
      array[array_size++] = SortChar(buffer);
    }
  }
 
  for (i = 0; i < array_size; ++i) {
    printf("%s\n", array[i]);
    free(array[i]);
  }
  free(array);
  return 0;
}
accept
4837 / 3236 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
22.02.2011, 05:06     Написание функции #3
C
1
while (!feof(stdin)) {
ошибка в stdin приведёт к бесконечному циклу
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9371 / 5421 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
22.02.2011, 10:08     Написание функции #4
Цитата Сообщение от accept Посмотреть сообщение
ошибка в stdin приведёт к бесконечному циклу
На сколько помню, на следующей итерации после той, в которой произошла ошибка, флаг EOF возведётся, но в принципе - да, не комильфо. Правильнее проверять результат чтения. То есть, когда не удалось прочитать из файла очередной символ/строку/буфер определённого размера, вот тогда и надо разбираться - файл там закончился, или ошибка чтения случилась (man ferror)...
accept
4837 / 3236 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
24.02.2011, 08:35     Написание функции #5
Цитата Сообщение от easybudda
На сколько помню, на следующей итерации после той, в которой произошла ошибка, флаг EOF возведётся
сам он не возведётся, так как эти флаги устанавливаются функциями, fgets() будет устанавливать флаг ошибки снова и снова
эти флаги не зависят друг от друга
ewenso
 Аватар для ewenso
0 / 0 / 0
Регистрация: 17.11.2011
Сообщений: 25
13.03.2012, 12:21     Написание функции #6
Привет всем!
Хотел спросить, данный код рабочий? или надо исправить вот это
C++
1
while (!feof(stdin)) {
и все тип топ будет?
ПРосто не могу проверить сейчас сам.
ewenso
 Аватар для ewenso
0 / 0 / 0
Регистрация: 17.11.2011
Сообщений: 25
15.03.2012, 16:27     Написание функции #7
Все понял, тут исп файл...Не могли бы Вы показать такой же пример, этого же задания, но не используя файлы, а чтоб сразу пользователь ввел массив, и нам выводиться как по заданию...
Уже 4 час лажу в интернете и немогу найти как ввести и отсортировать...

п.с посоветуйте литературу для чайников.
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9371 / 5421 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
15.03.2012, 17:11     Написание функции #8
Цитата Сообщение от ewenso Посмотреть сообщение
Уже 4 час лажу в интернете и немогу найти как ввести и отсортировать...
Так здесь же всё есть, переделать только немного...
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
    
int cmp(const void * a, const void * b){
    return *(char*)a - *(char*)b;
}
 
char * strsort(char * str){
    qsort(str, strlen(str), sizeof(char), cmp);
    return str;
}
 
int main(void){
    char buf[BUFSIZ];
    
    while ( printf("String: ") && fgets(buf, BUFSIZ, stdin) && *buf != '\n' ){
        char * tail = strrchr(buf, '\n');
        if ( tail )
            *tail = '\0';
        printf("Result: %s\n", strsort(buf));
    }
    
    return 0;
}
ewenso
 Аватар для ewenso
0 / 0 / 0
Регистрация: 17.11.2011
Сообщений: 25
15.03.2012, 17:22     Написание функции #9
Ну для Вас может это и просто, я сморю и просто, как ироглифы У нас препод такой, что нечего толком рассказать не могут...
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
17.03.2012, 15:44     Написание функции
Еще ссылки по теме:

C++ Написание функции для счета в динамическом массиве
Написание программы вычисления функции. Ошибка C++
C++ Написание рекурсивной функции вычисления многочлена по схеме Горнера

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

Или воспользуйтесь поиском по форуму:
ewenso
 Аватар для ewenso
0 / 0 / 0
Регистрация: 17.11.2011
Сообщений: 25
17.03.2012, 15:44     Написание функции #10
Вопрос все еще актуален.
Yandex
Объявления
17.03.2012, 15:44     Написание функции
Ответ Создать тему
Опции темы

Текущее время: 19:41. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru