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

итересная прога с функцией распределения элементов массива:) - C++

Восстановить пароль Регистрация
 
Sanu0074
 Аватар для Sanu0074
58 / 58 / 2
Регистрация: 14.06.2010
Сообщений: 1,186
Записей в блоге: 5
29.06.2010, 21:21     итересная прога с функцией распределения элементов массива:) #1
- вводим одномерный символьный массив
C++
1
2
3
4
5
6
7
#include <iostream>
using namespace std;
//сюда функцию распределения
int main()
{
    char mass[28];
    cin>>mass;
- с помощью фунуции перебираем массив, если элемент число - записываем его в int, если символ - пишем в char; если 1й эл. - число и следующий эл. тоже число - пишем в int - только как двузначное число...
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.06.2010, 21:21     итересная прога с функцией распределения элементов массива:)
Посмотрите здесь:

C++ Сортировка массива функцией
C++ Определение кол-ва нечетных элементов массива с функцией
Написать датчик случайных чисел с таблично заданной функцией распределения C++
Двумерный массив с функцией ( найти среднеквадратичное значение положительных элементов каждой строки массива) C++
Вычислить среднее арифметическое отрицательных элементов массива. Использовать функцией для каждой строки матрицы А (4, 8) C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
PointsEqual
ниначмуроФ
 Аватар для PointsEqual
832 / 516 / 33
Регистрация: 12.10.2009
Сообщений: 1,915
30.06.2010, 09:56     итересная прога с функцией распределения элементов массива:) #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
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
#include <iostream>
#include <conio.h>
#include <sstream>
#include <iomanip>
 
int fromst(const std::string& s);
 
int main()
{
    const int size=16;
    char m_main[size]={'1','a','2','b','3','4','5','6','c','d','e','7','8','v','9','9'};
    char m_char[size]={};
    const int size2=(size/2)+1; //максимальный размер для массива целых = (size/2)+1
    int m_int[size2]={};
 
    int cnt_char=0;
    int cnt_int=0;
    std::string st;
    st.clear();
 
    //распределение
    int i=0;
    while ( i < size ){
        if ( isalpha(m_main[i]) ){
            if (!st.empty()){
                m_int[cnt_int]=fromst(st);
                ++cnt_int;
                st.clear();
            }
            m_char[cnt_char]=m_main[i];
            ++cnt_char;
            ++i;
        }
        while ( isdigit(m_main[i]) ){
            st+=m_main[i];
            ++i;
            if (i>=size)
            m_int[cnt_int]=fromst(st);
        }
    }
 
    //вывод на экран
    std::cout<<"Start mssiv:"<<std::endl;
    for (int i=0; i<size; ++i){
        std::cout<<std::setw(3)<<m_main[i];
    }
    std::cout<<std::endl<<std::endl;
 
    std::cout<<"Massiv char:"<<std::endl;
    for (int i=0; i<size; ++i){
        std::cout<<std::setw(3)<<m_char[i];
    }
    std::cout<<std::endl<<std::endl;
 
    std::cout<<"Massiv int:"<<std::endl;
    for (int i=0; i<size2; ++i){
        std::cout<<std::setw(5)<<m_int[i];
    }
 
    getch();
    return EXIT_SUCCESS;
}
 
 
int fromst(const std::string& s)
{
    std::istringstream iss(s);
    int res;
    iss >> res;
    return res;
}
[функцию не выносил]
Миниатюры
итересная прога с функцией распределения элементов массива:)  
Sanu0074
 Аватар для Sanu0074
58 / 58 / 2
Регистрация: 14.06.2010
Сообщений: 1,186
Записей в блоге: 5
30.06.2010, 12:42  [ТС]     итересная прога с функцией распределения элементов массива:) #3
Цитата Сообщение от PointsEqual Посмотреть сообщение
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
#include <iostream>
#include <conio.h>
#include <sstream>
#include <iomanip>
 
int fromst(const std::string& s);
 
int main()
{
    const int size=16;
    char m_main[size]={'1','a','2','b','3','4','5','6','c','d','e','7','8','v','9','9'};
    char m_char[size]={};
    const int size2=(size/2)+1; //максимальный размер для массива целых = (size/2)+1
    int m_int[size2]={};
 
    int cnt_char=0;
    int cnt_int=0;
    std::string st;
    st.clear();
 
    //распределение
    int i=0;
    while ( i < size ){
        if ( isalpha(m_main[i]) ){
            if (!st.empty()){
                m_int[cnt_int]=fromst(st);
                ++cnt_int;
                st.clear();
            }
            m_char[cnt_char]=m_main[i];
            ++cnt_char;
            ++i;
        }
        while ( isdigit(m_main[i]) ){
            st+=m_main[i];
            ++i;
            if (i>=size)
            m_int[cnt_int]=fromst(st);
        }
    }
 
    //вывод на экран
    std::cout<<"Start mssiv:"<<std::endl;
    for (int i=0; i<size; ++i){
        std::cout<<std::setw(3)<<m_main[i];
    }
    std::cout<<std::endl<<std::endl;
 
    std::cout<<"Massiv char:"<<std::endl;
    for (int i=0; i<size; ++i){
        std::cout<<std::setw(3)<<m_char[i];
    }
    std::cout<<std::endl<<std::endl;
 
    std::cout<<"Massiv int:"<<std::endl;
    for (int i=0; i<size2; ++i){
        std::cout<<std::setw(5)<<m_int[i];
    }
 
    getch();
    return EXIT_SUCCESS;
}
 
 
int fromst(const std::string& s)
{
    std::istringstream iss(s);
    int res;
    iss >> res;
    return res;
}
[функцию не выносил]
большое спс))

а можно немного прокоментить код?
PointsEqual
ниначмуроФ
 Аватар для PointsEqual
832 / 516 / 33
Регистрация: 12.10.2009
Сообщений: 1,915
30.06.2010, 13:19     итересная прога с функцией распределения элементов массива:) #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
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
#include <iostream>
#include <conio.h>
#include <sstream>
#include <iomanip>
 
int fromst(const std::string& s); //прототип ф-ии, преобразующей строку-string в число
 
int main()
{
    const int size=16;
    char m_main[size]={'1','a','2','b','3','4','5','6','c','d','e','7','8','v','9','9'}; //исходный массив
    char m_char[size]={}; // массив для символов
    const int size2=(size/2)+1; //максимальный размер для массива целых = (size/2)+1
    int m_int[size2]={}; // массив для чисел
 
    int cnt_char=0; //индекс для символьного массива
    int cnt_int=0; // индекс для числового массива
    std::string st; //  в эту строку помещаются только цифры из исходного массива
    st.clear();
 
    //распределение
    int i=0;
    while ( i < size ){ // пока в исходном массиве есть символы
        if ( isalpha(m_main[i]) ){ // если символ - буква, то
            if (!st.empty()){ // если строка st не пустая, то
                m_int[cnt_int]=fromst(st); // преобразуем строку в число и запихиваем в массив целых по индексу cnt_int
                ++cnt_int; //преход на следующую клетку массива целых
                st.clear(); // очистить строку
            }
            // иначе, если строка st пустая, значит встретилась опять буква
            m_char[cnt_char]=m_main[i]; //помещаем эту букву в символьный массив по индексу cnt_char
            ++cnt_char; //преход на следующую клетку символьного массива 
            ++i; //преход на следующий символ исходного массива
        }
        // иначе, если текущий символ - не буква, то
        while ( isdigit(m_main[i]) ){ //до тех пор пока не встретится буква (или пока текущий символ - цифра)
            st+=m_main[i]; //добавляем к строке цифру  
            ++i; //преход на следующий символ исходного массива
            // следующие 2 строки нужны для того чтобы ......  как бы объяснить..вообщем
            //если их не написать, то если в исходном массиве - последние символы - цифры, то они не будут  заносится в массив целых
            if (i>=size){
                m_int[cnt_int]=fromst(st);
            }
        }
    }
 
    //вывод на экран
    std::cout<<"Start mssiv:"<<std::endl;
    for (int i=0; i<size; ++i){
        std::cout<<std::setw(3)<<m_main[i];
    }
    std::cout<<std::endl<<std::endl;
 
    std::cout<<"Massiv char:"<<std::endl;
    for (int i=0; i<size; ++i){
        std::cout<<std::setw(3)<<m_char[i];
    }
    std::cout<<std::endl<<std::endl;
 
    std::cout<<"Massiv int:"<<std::endl;
    for (int i=0; i<size2; ++i){
        std::cout<<std::setw(5)<<m_int[i];
    }
 
    getch(); // ждать нажатие клавиши
    return EXIT_SUCCESS;
}
 
 
int fromst(const std::string& s)
{
    std::istringstream iss(s);
    int res;
    iss >> res;
    return res;
}
размер size2 - вычисляет максимальную длину целочисленного массива она равна (грубо) size/2 , но впринципе можно везде ставить просто size

Добавлено через 4 минуты
Цитата Сообщение от PointsEqual Посмотреть сообщение
C++
1
2
if ( isalpha(m_main[i]) ){ // если символ - буква, то
 if (!st.empty()){ // если строка st не пустая, то
если мы встретили симол, то проверим , нет ли в st цифр, если есть - то заносим их в массив целых, если же их нет (если st пустая) то просто заносим символ в масиив символов.

вообщем я не очень хорошо объясняю.
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9371 / 5421 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
30.06.2010, 16:18     итересная прога с функцией распределения элементов массива:) #5
Читает строку, выводит по отдельности числа и слова. Если есть на свете "Высокое Порно", то это должно быть "Высоким Быдлокодом" Превышение INT_MAX не отслеживает, потому слишком длинные числа обрабатывает неправильно, а так вроде работает...
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
#include <iostream>
#include <string>
#include <sstream>
#include <list>
#include <algorithm>
#include <iterator>
#include <cctype>
 
int main(){
    int num;
    char c;
    std::string strNum, strWrd;
    std::list<int> numbers;
    std::list<std::string> words;
 
    std::cout << "String: ";
 
    strNum = strWrd = "";
    while ( std::cin.get(c) ) {
        if ( isspace(c) ){
            if ( ! strNum.empty() ){
                std::stringstream ss;
                ss << strNum;
                ss >> num;
                numbers.push_back(num);
                strNum = "";
            }
            if ( ! strWrd.empty() ){
                words.push_back(strWrd);
                strWrd = "";
            }
            if ( c == '\n' )
                break;
        }
        else if ( isdigit(c) ){
            if ( ! strWrd.empty() ){
                words.push_back(strWrd);
                strWrd = "";
            }
            strNum += c;
        }
        else {
            if ( ! strNum.empty() ){
                std::stringstream ss;
                ss << strNum;
                ss >> num;
                numbers.push_back(num);
                strNum = "";
            }
            strWrd += c;
        }
    }
 
    if ( ! numbers.empty() ){
        std::cout << "Numbers:" << std::endl;
        std::copy(numbers.begin(), numbers.end(), std::ostream_iterator<int>(std::cout, "\n"));
    }
    if ( ! words.empty() ){
        std::cout << "Words:" << std::endl;
        std::copy(words.begin(), words.end(), std::ostream_iterator<std::string>(std::cout, "\n"));
    }
 
    return 0;
}
Sanu0074
 Аватар для Sanu0074
58 / 58 / 2
Регистрация: 14.06.2010
Сообщений: 1,186
Записей в блоге: 5
30.06.2010, 16:25  [ТС]     итересная прога с функцией распределения элементов массива:) #6
спс
Yandex
Объявления
30.06.2010, 16:25     итересная прога с функцией распределения элементов массива:)
Ответ Создать тему
Опции темы

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