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

Функция rand() - C++

Восстановить пароль Регистрация
 
J4SSektor
0 / 0 / 0
Регистрация: 13.01.2013
Сообщений: 19
30.01.2013, 20:14     Функция rand() #1
Здравствуйте, имеется код с реализацией алгоритма прямого поиска и я не могу понять как задается длина строки и подстроки, в частности интересуют эти строки:
C++
1
2
const char* string=random_string(rand()%15+1);
      char substring[N];
Объясните plz.
Весь код целиком:
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
#include <iostream>
#include <cstdlib>
 
char* random_string(size_t len) {
   const char alph[] =
       "0123456789"
       "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
       "abcdefghijklmnopqrstuvwxyz";
 
   char* buf = (char*)malloc(len+1);
   size_t i;
 
   for (i = 0; i < len; ++i)
       buf[i] = alph[rand() % (sizeof(alph)-1)];
 
   return buf;
}
 
using namespace std;
int DirectSearch (char *string, char *substring){
    int sl, ssl;
    int res=-1;
    sl=strlen(string);
    ssl=strlen(substring);
    if (sl==0)
        cout<< "Neverno zadana stroka\n";
    else if (ssl==0)
        cout<< "Neverno zadana podstroka\n";
    else
        for (int i=0; i<sl-ssl+1;i++)
            for (int j=0; j<ssl;j++)
                if (substring[j]!=string[i+j])
                    break;
                else if (j==ssl-1){
                    res=i;
                    break;
                }
    return res;
}
 
#define N 9
int main ( void )
{
    srand(time(0));
    const char* string=random_string(rand()%15+1);
          char substring[N];
    int   result;
    printf("String=%s\n",string);
    scanf("%10s",substring);
    printf("\nSubstring = %s\n",substring);
    printf("Pos:%d",DirectSearch(string,substring));
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
30.01.2013, 20:14     Функция rand()
Посмотрите здесь:

C++ Функция rand();
Функция rand() C++
C++ функция rand()
Функция rand() C++
C++ функция rand()
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Croessmah
Модератор
Эксперт С++
 Аватар для Croessmah
11819 / 6798 / 769
Регистрация: 27.09.2012
Сообщений: 16,870
Записей в блоге: 2
Завершенные тесты: 1
30.01.2013, 20:57     Функция rand() #2
C++
1
rand()%15+1
от возвращенного функцией rand псевдослучайного числа берется остаток от деления на 15, т.е. максимум будет 14 и к этому остатку прибавляется 1. Получаем диапазон генерируемых чисел [1;15]
C++
1
2
3
#define N 9
//...
char substring[N];
массив char'ов из 9 элементов

И, вроде, заголовка <ctime> не хватает
J4SSektor
0 / 0 / 0
Регистрация: 13.01.2013
Сообщений: 19
30.01.2013, 21:08  [ТС]     Функция rand() #3
Т.е. запросто может быть так, что подстрока будет длиннее строки?
Croessmah
Модератор
Эксперт С++
 Аватар для Croessmah
11819 / 6798 / 769
Регистрация: 27.09.2012
Сообщений: 16,870
Записей в блоге: 2
Завершенные тесты: 1
30.01.2013, 21:52     Функция rand() #4
Цитата Сообщение от J4SSektor Посмотреть сообщение
Т.е. запросто может быть так, что подстрока будет длиннее строки?
может, но в таком случае ни разу не войдем в цикл и вернется -1 из функции
C++
1
for (int i=0; i<sl-ssl+1;i++)
а тут:
C++
1
buf[i] = alph[rand() % (sizeof(alph)-1)];
символ 'z' не будет выбран никогда

Добавлено через 8 минут
Цитата Сообщение от Croessmah Посмотреть сообщение
символ 'z' не будет выбран никогда
Нагло вру! Будет. Забыл про '\0' в конце
Yandex
Объявления
30.01.2013, 21:52     Функция rand()
Ответ Создать тему
Опции темы

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