Главная Случайная страница Контакты | Мы поможем в написании вашей работы! | ||
|
Также как и для числовых массивов, прежде, чем начать работу над символьным массивом, необходимо выделить для него область памяти, не забыв при этом поставить знак $ после имени массива.
Например, DIM A$(5), B$(10).
Над элементами строкового массива можно производить те же операции, что и над простыми строковыми переменными, то есть склейку слов и выделение подслов.
Задавать символьный массив можно тоже одним из трех, выше описанных способов — с помощью INPUT, DATA и READ и генератором случайных чисел RND.
Рассмотрим последний способ. Здесь мы будем использовать функцию CHR$(N), где N — натуральное число от 0 до 255. Эта функция переводит число в соответствующий ему символ.
Известно, что коды латинских букв упорядочены по алфавиту и, начиная с 65 идут коды заглавных букв, а с 97 — коды маленьких букв. Коды заглавных русских букв — с 128 до 159, а коды строчных русских букв по алфавиту не упорядочены.
Например, INT(RND*25+65) даст случайное число в интервале от 65 до 90, то есть в интервале больших латинских букв, а CHR$(INT(RND*25+65)) преобразует этот код в символ.
Задача 1.
Даны символы s1,s2,...,s30. Получить символы данной последовательности в обратном порядке.
Решение.
CLS
DIM S$(30), A$(30):’отводим место в памяти
FOR I=1 TO 30 STEP 1:’задаем массив
S(I)= CHR$(INT(RND*25+65)):’ из больших латинских букв
PRINT S$(I);:’печать массива в одну строку
NEXT I
PRINT:’отмена вывода в текущей строке
FOR I=1 TO 30 STEP 1:’задаем массив A$
A$(I)= S$(31-I):’А$(1)=S$(30), А$(2)=S$(29)...
PRINT A$(I);:’печать массива в одну строку
NEXT I
END
Задача 2.
В массиве слов найти слова, содержащие последним символом букву “о”. Вывести на печать эти элементы и их номера, распечатать весь массив.
Примечание: Необходимо завести переменную, которая будет служить “сигнальной лампочкой”, то есть будет показывать есть ли в массиве слова, кончающиеся на “о” или нет. В начале программы “лампочке” присваивается значение, равное нулю. Если значение останется нулевым, то это значит, что таких слов нет.
Решение.
CLS
DIM A$(10):REM oтводим место в памяти
DATA Окно, Дом, Труба, Дерево, Цветы, Бревно
DATA Золото, Сон, Поле, Дело
FOR I=1 TO 10 STEP 1
READ A$(I):REM задаем массив
PRINT A$(I);:REM печатаем массив
NEXT I
L=0:REM “сигнальная лампочка”
FOR I=1 TO 10 STEP 1
C$=MID$(A$(I), LEN(A$(I)), 1): ‘копируем последнюю букву и
IF C$=“o” THEN PRINT A$(I), I, “элемент”:’сравниваем с “о”
L=1:’ если буквы совпадают,
NEXT I:’ лампочка меняет значение
IF L=0 THEN
PRINT “Слов с последней буквой /О/ в массиве нет”
END IF
END
Задача 3.
Список содержит фамилии 12 учеников и из возраст. Найти фамилии тех, кому больше 16 лет.
Решение:
CLS
DIM N$(12), W(12)
DATA ИВАНОВ, ПЕТРОВ, ВАСЕЧКИН, КРЫЛОВА
DATA ФЕДИНА, БОБКОВА, ЗАЙЦЕВ, ХРУЩЕВ, ГРИШИН
DATA СИДОРОВА, БОБРОВ, МОКРУШИНА
DATA 12, 14, 16, 17, 7, 10,12, 9, 17, 17, 8, 17
FOR I=1 TO 12 STEP 1
READ N$(I)
NEXT I
FOR I=1 TO 12 STEP 1
READ W(I)
NEXT I
FOR I=1 TO 12 STEP 1
PRINT N$(I); “-”; W(I)
NEXT I
PRINT “ Старше 16 лет:“
FOR I=1 TO 12 STEP 1
IF W(I) > 16 THEN PRINT N$(I);
NEXT I
END
Дата публикования: 2014-12-28; Прочитано: 214 | Нарушение авторского права страницы | Мы поможем в написании вашей работы!