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

Вести строку - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Функции,файлы, структуры http://www.cyberforum.ru/cpp-beginners/thread898138.html
Для хранения данных о планшетных сканерах описать структура вида: struct scan_info{ char model; //наименование int price; //цена double x_size; //горизонтальный размер области сканирования double y_size; //вертикальный размер области сканирования int optr; оптическое разрешение int grey; //число градаций серого }; 1)Написать функцию, которая записывает в бинарный файл данные о сканере из...
C++ Вычислить значения функции F на интервале Добрый вечер, ув. программисты! Мне осталась последняя программа, которую нужно написать. Но появилась такая проблема - я не могу её написать на C++. Помогите, пожалуйста, очень надо на завтра, последняя сдача программ. Заранее спасибо. Вот сама программа: Вычислить и вывести на экран в виде таблицы значения функции F на интервале от Хнач. до Хкон. с шагом dX.... http://www.cyberforum.ru/cpp-beginners/thread898129.html
Дана целочисленная квадратная матрица 9х9. Определить: C++
(2) Дана целочисленная квадратная матрица 9х9. Определить: 1) сумму элементов в тех строках, которые содержат хотя бы один отрицательный элемент; 2) минимум среди сумм элементов диагоналей, параллельных главной диагонали матрицы.
C++ Вычислить по формуле
Добрый вечер, ув. программисты! Очень нужна Ваша помощь. Программа легкая, но я не знаю как написать её на C++. Заранее спасибо. Тема такая: Дано натуральное n. Вычиcлить:
C++ Коментарии http://www.cyberforum.ru/cpp-beginners/thread898102.html
#include <locale> #include <stdio.h> #include <stdlib.h> #include <conio.h> void main() { setlocale(LC_ALL,"Russian"); int N,i,kmax,numplay,numk,kol,*A; bool flag1,flag2,flag;
C++ Дана матрица. Переставляя ее строки и столбцы, переместить наибольший элемент в верхний левый угол Помогите пожалуйста студенту выйти на стипендию)) напишите программу Дана матрица NxM. Переставляя ее строки и столбцы, переместить наибольший элемент в верхний левый угол. Определить можно ли таким же образом поместить минимальный элемент в нижний правый угол. подробнее

Показать сообщение отдельно
Miwa123
37 / 37 / 1
Регистрация: 16.04.2013
Сообщений: 317
Записей в блоге: 1
11.06.2013, 02:22  [ТС]     Вести строку
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
void binar_search()
{
    char text[200],arr[50],simb;
    cin.getline(text, 200);
    cin>>simb;
        memset(arr,0,sizeof(arr));//заполняем массив арр нулями
    for(int i=0,j=0;i<strlen(text);i++)//с помощью цыкла в массив arr заносим первые буквы каждого слова из массива text
        if((isalnum((unsigned char)text[i])))//проверка на символ
            {
                if(!arr[j])
            arr[j]=text[i];
            }
        else
            j++;
 
            
    
         int average_index = 0, // переменная для хранения индекса среднего элемента массива
       first_index   = 0, // индекс первого элемента в массиве
       last_index    = strlen(arr)-1; // индекс последнего элемента в массиве
 
      char search_value  = simb; // искомое (ключевое) значение
 
       while (first_index < last_index)
    {
        average_index = first_index + (last_index - first_index) / 2; // меняем индекс среднего значения
        int(search_value) <= int(arr[average_index]) ? last_index = average_index : first_index = average_index + 1;    // найден ключевой элемент или нет 
    }
    if ( int(arr[last_index]) == int(search_value))//если процесс прошел успешно выведем результат
        cout << "\Cлово под нормером: "<< last_index << endl;
    else//если нет выведем следующую строку
        cout << "\Не найдено" << endl;
}
весь смысла нет. ф-ия то без параметров
Кликните здесь для просмотра всего текста

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
#include "stdafx.h"
#include <iostream>
#include <cstdlib>
using namespace std;
void posled(char*,char*,int);//последовательный поиск
void binar_search();//бинарный поиск
int main()
{
    setlocale(LC_ALL,"RUSSIAN");
   char text[250],word[10];//массивы для хранения текста и слова!
   cout<<"Введите текст: ";
  cin.getline(text, 250);
//Вводим текст
    cout<<"Введите слово: ";
   cin>>word;//Вводим слово
   cout<<"Совпадения по 1 букве: ";posled(text,word,1);//передаем в функцию текст слово и количество элементов совпадения
    cout<<"Совпадения по 2 буквы: ";posled(text,word,2);
     cout<<"Совпадения по 3 буквы: ";posled(text,word,3);
     cout<<"Совпадения по 4 буквы: ";posled(text,word,4);
     binar_search();
    system("pause");
    return 0;
}
void posled(char* text,char*slovo,int kolvobukv)
{
int count=0,c=0,sovpaden=0;
char *p;
p=text;//ставим указатель на начало текста
for(int i=0;i<strlen(text)+1;i++)
{
    if(isalnum((unsigned char)text[i]))
        count++;//если символы - буквы или цифры инкрементируем счетчик
    else
    {//как только нам попадаеться пробел или знак препинания мы 
        if(count)
            for(int x=0;x<kolvobukv && count>=kolvobukv;x++)//начинаю с указателя в упор до знака припинания
            {//проверяем сиволы
                if(slovo[x]==*p)
                c++;//сумма совпавших букв
                p++;//указатель 
            }
            if(kolvobukv==c)//если количество буква равна количеству совпавших букв
                sovpaden++;//инкрементируем счетчик совпадений
            c=0;//и обнуляем счетчик совпавших букв
            p+=count-kolvobukv+1;//перемешаем счетчик на 1ую букву следующего слова
            count=0;//также счетчик символов
    }
}
cout<<sovpaden<<endl;
}
void binar_search()
{
    char text[200],arr[50],simb;
    cin.getline(text, 200);
    cin>>simb;
        memset(arr,0,sizeof(arr));//заполняем массив арр нулями
    for(int i=0,j=0;i<strlen(text);i++)//с помощью цыкла в массив arr заносим первые буквы каждого слова из массива text
        if((isalnum((unsigned char)text[i])))//проверка на символ
            {
                if(!arr[j])
            arr[j]=text[i];
            }
        else
            j++;
 
            
    
         int average_index = 0, // переменная для хранения индекса среднего элемента массива
       first_index   = 0, // индекс первого элемента в массиве
       last_index    = strlen(arr)-1; // индекс последнего элемента в массиве
 
      char search_value  = simb; // искомое (ключевое) значение
 
       while (first_index < last_index)
    {
        average_index = first_index + (last_index - first_index) / 2; // меняем индекс среднего значения
        int(search_value) <= int(arr[average_index]) ? last_index = average_index : first_index = average_index + 1;    // найден ключевой элемент или нет 
    }
    if ( int(arr[last_index]) == int(search_value))//если процесс прошел успешно выведем результат
        cout << "\Cлово под нормером: "<< last_index << endl;
    else//если нет выведем следующую строку
        cout << "\Не найдено" << endl;
}
 
Текущее время: 12:51. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru