
- •Передмова 4
- •Передмова
- •Список літератури
- •Лабораторна робота № 1 Тема: «Робота з двовимірними масивами»
- •Мета роботи
- •Завдання до лабораторної роботи
- •2.1 Методичні вказівки
- •2.2 Приклад програми
- •2.3 Контрольні питання
- •Варіанти завдань
- •Прилади, устаткування та інструменти
- •Правила техніки безпеки та охорони праці
- •Порядок проведення лабораторної роботи
- •2.1 Методичні вказівки
- •Рекурсивне обчислення значення факторіала натурального числа
- •Рекурсивне обчислення чисел Фібоначчі
- •Рекурсивне обчислення найбільшого спільного дільника двох чисел
- •Рекурсивний метод піднесення до ступеня
- •2.2 Приклад програми
- •2.3 Контрольні питання
- •Варіанти завдань
- •Прилади, устаткування та інструменти
- •Правила техніки безпеки та охорони праці
- •Порядок проведення лабораторної роботи
- •Методи класу Arrays»
- •Методичні вказівки
- •Приклад програми
- •2.3 Контрольні питання
- •Варіанти завдань
- •Прилади, устаткування та інструменти
- •Правила техніки безпеки та охорони праці
- •Порядок проведення лабораторної роботи
- •6. Оформлення і захист звіту
- •2.1 Методичні вказівки
- •2.2 Приклад програми
- •2.3 Контрольні питання
- •2.4 Варіанти завдань
- •Прилади, устаткування та інструменти
- •Правила техніки безпеки та охорони праці
- •Порядок проведення лабораторної роботи
- •2.1 Методичні вказівки
- •Клас Stack
- •Однонаправлений зв'язний список
- •2.2 Приклад програми
- •2.3 Контрольні питання
- •2.4 Варіанти завдань
- •Прилади, устаткування та інструменти
- •Правила техніки безпеки та охорони праці
- •Порядок проведення лабораторної роботи
- •6 Оформлення і захист звіту
- •Методичні вказівки
- •65016, М. Одеса, вул. Львівська, 15
2.2 Приклад програми
Прочитати рядки з текстового файлу і поміняти місцями перше і останнє слово в кожному рядку, новий текст записати в той же файл.
import java.io.*;
class Primer{
public static void main(String[] args){
String fileName=args[0];
try{
FileReader fr = new FileReader(fileName);
BufferedReader br = new BufferedReader(fr);
FileWriter fw = new FileWriter(fileName,true);;
BufferedWriter bw = new BufferedWriter(fw);
PrintWriter pw = new PrintWriter(bw);
String s = null;
int count = 0;
pw.println();
while((s=br.readLine())!=null){
int nom1=s.indexOf(' ');
String s1=s.substring(0,nom1+1);// Перше слово
int nom2=s.lastIndexOf(' ');
String s2=s.substring(nom2,s.length());//Останнє слово
String s3=s.substring(nom1,nom2+1);
s=s2+s3+s1;
pw.println(s);}
br.close(); pw.close();
}catch(Exception e){
e.printStackTrace();}
}}
Другий варіант програми з використанням методів класу StringTokenizer
import java.io.*;
import java.util.*;
class Primer{
public static void main(String[] args){
String fileName=args[0];
try{
FileReader fr = new FileReader(fileName);
BufferedReader br = new BufferedReader(fr);
FileWriter fw = new FileWriter(fileName,true);;
BufferedWriter bw = new BufferedWriter(fw);
PrintWriter pw = new PrintWriter(bw);
String s = null,s1=null,s2=null,s3=null;
int count = 0;
pw.println();
while((s=br.readLine())!=null){
s2="";
StringTokenizer st = new StringTokenizer(s, " \t\n\r,.");
int n=0;
while(st.hasMoreTokens()){
if (n==0) s1=st.nextToken(); //Перше слово
else
{if (st.countTokens()==1) s3=st.nextToken();//Останнє слово
else s2+=st.nextToken();}
n++;}
s=s3+" "+s2+" "+s1;
pw.println(s);}
br.close(); pw.close();
}catch(Exception e){
e.printStackTrace(); }}}
2.3 Контрольні питання
1. За допомогою яких методів можна перетворити в рядок змінні примітивних типів і масив символів? Як перетворити з String в примітивний тип? Приведіть приклади.
2. Які методи класу String дозволяють провести заміну регістра букв?
3. У яких випадках використовується клас StringBuffer? Як можна встановити ємність буфера для об'єкту класу StringBuffer? Опишіть конструктори даного класу.
4. Дайте короткий опис конструкторам і методам класу StringTokenizer.
5. У чому відмінність між наступними фрагментами коду:
1. String s1 = "abc";
String s2 = new String("abc");
boolean result = (s1==s2);
2. String s1 = new String("abc");
String s2 = new String("abc");
boolean result = (s1.equals(s2));
6. Як в Java можна організувати файлові потоки введення-виведення?
2.4 Варіанти завдань
1. Прочитати текст Java-програми і всі слова "public" в оголошенні атрибутів класу замінити на "private". Новий текст записати в той же файл.
2. Прочитати текст Java-програми і записати в інший файл у зворотному порядку символи кожного рядка.
3. Прочитати текст Java-програми і в кожному слові коротше за п'ять символів всі символи замінити знаком *. Результат записати в інший файл.
4. Напишіть програму для проведення пошуку і заміни слів в тексті. Вона повинна приймати три параметри виклику методу main(): ім'я файлу, рядок для пошуку і рядок для заміни. В результаті її роботи створюється файл з ім'ям res.txt, що містить результати заміни.
5. Прочитати текст Java-програми і видаліть з нього всі слова що починаються з символу ‘p’. Новий текст виведіть в інший файл.
6. Прочитати текст Java-програми і в кожному слові довше за два символи всі рядкові символи замінити прописними. Результат записати в інший файл.
7. З файлу видалити всі слова, що містять від трьох до п'яти символів, але при цьому з кожного рядка треба видалити тільки максимальну парну кількість таких слів.
8. У файлі, що містить в кожному окремому рядку прізвища студентів і їх оцінки, записати великими буквами прізвища тих студентів, які мають середній бал більше "4". Приклад файлу:
Петренко 5 4 5 3 3
Шевченко 5 5 4 3
9. Прочитати текст Java-програми і визначити, скільки в ньому оголошених класів. Видалити в оголошенні класів модифікатор "public". Результат вивести в той же файл.
10. З тексту Java-програми видалити коментарі виду // і /* */. Новий текст записати в той же файл.
11. Створити і заповнити файл випадковими цілими числами. Відсортувати вміст файлу за збільшенням і результати вивести в цей же файл.
12. Прочитати текст Java-програми і видалити з нього всі "зайві" пробіли, залишивши тільки значущі.
13. Прочитати текст Java-програми і у вихідний файл записати всі статично виділені в програмі змінні типу int і double в наступному форматі:
Змінні типу int: a,b,c.
Змінні типу double: x,y,z.
14. Прочитати текст Java-програми і у вихідний файл записати всі цикли for разом з їх вмістом (у відповідності з синтаксисом циклу for). Цикли розділяти порожнім рядком. Вказівка: врахувати можливість існування вкладених циклів.
15. Прочитати текст Java-програми і у кожному рядку всі слова, довжина яких перевищує середню довжину слів в рядку, скоротити до середньої довжини. Результат записати в інший файл.