Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [С] сортировка по длине слова, в возрастающем порядке 
V
    Опции темы
Torrero
Дата 29.8.2007, 15:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 53
Регистрация: 14.11.2006

Репутация: нет
Всего: нет



задача такая,отсортировать по длине слова в возрастающем порядке любую фразу введеную с клавы...Я не прошу вас полностью писать программу,а прошу вас сказать алгоритм,как это все можно реализовать...а то у меня даже идеи нету просто...
PM MAIL   Вверх
APM
Дата 29.8.2007, 15:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 112
Регистрация: 13.7.2007

Репутация: 6
Всего: 6



1) Получаем фразу с клавиатуры
2) Составляем массив слов
3) Составляем массив #слова - количество букв
4) Сортируем этот массив по количеству букв
5) Выводим слова
PM   Вверх
Torrero
Дата 29.8.2007, 16:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 53
Регистрация: 14.11.2006

Репутация: нет
Всего: нет



Цитата(APM @ 29.8.2007,  15:30)
3) Составляем массив #слова - количество букв

я чегото несовсем понял,а можно по подробней чуток плиз
PM MAIL   Вверх
apook
Дата 29.8.2007, 17:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 794
Регистрация: 12.7.2006

Репутация: 10
Всего: 23



задача очень проста
составил массив

делаешь следующее условие:
ЕСЛИ длина слова со следующим  индексом меньше этого то меняем местами
например:
Код

char *tmp;
if( strlen(str[ 0 ]) < strlen(str[ 1 ]) )
{
    tmp=str[ 1 ];
    str[ 0 ] = str[ 1 ];
    str[ 1 ]=tmp;
    }

что-то такое

Цитата(APM @  29.8.2007,  15:30 Найти цитируемый пост)
3) Составляем массив #слова - количество букв


имелось ввиду наверно массив c длиной ряда по длине самого длинного слова smile
прросто напрашивалась такая мысль но если мы меняем указатели то ето не обязательно


--------------------
Мои руки из дуба, голова из свинца ну и пусть ...
PM MAIL   Вверх
Torrero
Дата 29.8.2007, 23:27 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 53
Регистрация: 14.11.2006

Репутация: нет
Всего: нет



apook,
 плин сори но у мну не совсем получаеться:(.я разбиваю фразу на слова,пытался дальше чето сделать,разные варианты,но нифига толком не вышло... smile 
помоги мну плиз...


PM MAIL   Вверх
apook
Дата 30.8.2007, 05:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 794
Регистрация: 12.7.2006

Репутация: 10
Всего: 23



Код

#include<iostream.h>
#include<string.h>
#include<conio.h>


int main()
{
int i, j, c;
char *str=new char[ 1000 ], *p=NULL, **strarray, *tmp=NULL;

//ввод считывание
cout << "Enter string: ";
cin.getline( str, 1000 );

//подсчет слов чтоб создать масссив
for( i=0, j=0; str[ i ]!='\0'; i++ )
    if( str[ i ]==' ' && str[ i+1 ]!=' ' )
        ++j;
++j;

//создаем пустой массив
strarray=new char*[ j ];
for( i=0; i<j; i++ )
    strarray[ i ]=new char[ 80 ];

p=strtok( str, " " );

for( i=0; ; i++ )
{
    if( p )
    {
        //заполняем массив
        strcpy( strarray[ i ], p);
        }
    else
        break;

    p=strtok( NULL, " " );
    }

//для наглядности вывод до сортировки
for( i=0; i<j; i++ )
    cout << strarray[ i ] << endl;
cout << "------------------------" << endl;

//сортировка по длине(в порядке убывания)!
for( c=0; c<j; c++ )
{
    for( i=0; i<j-1; i++ )
    {
        if( strlen(strarray[ i ])<strlen(strarray[ i+1 ]) )
        {
            tmp=strarray[ i ];
            strarray[ i ]=strarray[ i+1 ];
            strarray[ i+1 ]=tmp;
            }
        }
    }

//вывод после сортировки
for( i=0; i<j; i++ )
    cout << strarray[ i ] << endl;


//удаляемм массивы
delete [] str;

for( i=0; i<j; i++ )
    delete [] strarray[ i ];
delete [] strarray;

return 0;
}

строку вводишь разделяя слова пробелами знаки препинания в данном примере не учитываются

Это сообщение отредактировал(а) apook - 30.8.2007, 05:20


--------------------
Мои руки из дуба, голова из свинца ну и пусть ...
PM MAIL   Вверх
Rockie
Дата 1.9.2007, 03:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1143
Регистрация: 23.4.2006

Репутация: 13
Всего: 31



Код

#include <stdio.h>
#include <string.h>
#include <malloc.h>

int main()
{
    int rows = 0;        // количество слов
    int cols = 256;        // максимальная длина слова
    int i = 0, j=0;            // счетчик

    printf("How much words? ");    // спросим сколько слов
    scanf("%d",&rows);
  
    // выделили память под указатели на строки
    char** words = (char**)malloc(rows * sizeof(char*));   

    // затем на каждый указатель выделяем память под саму строку
    for(i=0;i<rows;i++)
        //words[i] = (char*)malloc(sizeof(cols * sizeof(char)));
        words[i] = (char*)malloc(cols * sizeof(char));  

    //считываем слова в массив
    for(i=0;i<rows;i++) scanf("%s",words[i]);

    // собственно сорировка, самая простая, пузырьком
    int flag = 1;    // флаг, что обменов не было
    while(flag)                                   
    { 
        flag=0;
        for(i=1;i<rows;i++)  
            {
                if(strlen(words[i-1])>strlen(words[i]))      
                { 
                    // меняем указатели
                    char* tmp=words[i-1]; words[i-1]=words[i]; words[i]=tmp; flag=1;
                }
          }
    }

    // распечатываем массив
    for(i=0;i<rows;i++)
        printf("%s\n",words[i]);

    getchar();
    return 0;
}


Работа программы:
Цитата

How much words? 5  123 3245 435436 43 32
43
32
123
3245
435436
Для продолжения нажмите любую клавишу . . .


Вот только хотелось бы все оставить так славненько, но есть для меня пока непонятный момент:

Компилятор VS2005. Добавляю блок 
Код

    // освобождаяем выделенную память также как и выделяли
    for(int i=0;i<rows;i++)
        free(words[i]);
    free(words);

В конфигурации Release - ничего. В Debug пошагово по F10 - ничего. А просто в Debug режиме - появляется табличка с надписью "HEAP CORRUPTION DETECTED: after normal block (#51) at 0x00342660. CRT detected that the application wrote to memory after end of heap buffer" Прервать/Повтор/Пропустить

Yep?.. smile



Это сообщение отредактировал(а) Rockie - 1.9.2007, 14:42


--------------------
Чтобы иметь большой гардероб - надо иметь большой гардероб.
PM   Вверх
Dov
Дата 1.9.2007, 13:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


аСинизатор
***


Профиль
Группа: Завсегдатай
Сообщений: 1721
Регистрация: 10.5.2003
Где: Эрец-Исраэль

Репутация: 50
Всего: 88



Rockie, в 19 строке первый sizeof - лишний.  smile 


--------------------
Тут вечности запах томительный,
И свежие фрукты дешевые, 
А климат у нас – изумительный, 
И только соседи – #уевые. 
                           Игорь Губерман.
PM   Вверх
Rockie
Дата 1.9.2007, 14:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1143
Регистрация: 23.4.2006

Репутация: 13
Всего: 31



Dov, точно!  smile 
подправил


--------------------
Чтобы иметь большой гардероб - надо иметь большой гардероб.
PM   Вверх
Torrero
Дата 4.9.2007, 16:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 53
Регистрация: 14.11.2006

Репутация: нет
Всего: нет



Псиб всем огромное за помощь,не ожидал что кто-то откликнеться

Это сообщение отредактировал(а) Torrero - 4.9.2007, 16:39
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.0950 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.