6804

Автоматизация разметки блок-схем алгоритмов

Лабораторная работа

Информатика, кибернетика и программирование

Автоматизация разметки блок-схем алгоритмов. Номер зачётной книжки: 831910 =100000011111112 Алгоритм обнаружения бесконечных циклов: Проверяем все операционные вершины на наличие перехода назад, если есть переход назад - помечаем блок д...

Русский

2013-01-08

84.4 KB

4 чел.

Автоматизация розметки блок-схем алгоритмов.

Номер зачётной книжки: 831910 =100000011111112;

Алгоритм обнаружения бесконечных циклов:

Проверяем все операционные вершины на наличие перехода назад, если есть переход назад  -  помечаем блок для проверки на зацикливание. Проверяем каждый такой блок на наличие переходов за пределы этого блока алгоритма. Если существует переход на врешину после исходной, то в данном блоке зацикливание не происходит. Если существует переход раньше входной то, то устанавливаем новую верхнюю границу блока, и вызываем функцию повторно.

Иначе выводим сообщение о бесконечном цикле, и номер вершины в которой обозначен неверный переход.

Скриншоты программы:

Листинг программы:

import java.io.Serializable;

import java.util.ArrayList;

public class Algorithm implements Serializable{

 private static final long serialVersionUID = 1L;

 

 private int[][] mConnections;

 private int[][] mSignals;

 private ArrayList<String> signals;

 private boolean[] isY;

 

 public Algorithm(){}

 public Algorithm(int[][] mC, int[][] mS, ArrayList<String> signs){

 System.out.println("Connection matrix:  ");

 mConnections =mC;

 mSignals = mS;

 signals = signs;

 isY = new boolean[mC.length];

 for(int i = 0; i < mC.length; i ++){

 int sum = 0;

  for(int j = 0; j<mC.length;j++) {

   sum+= mC[i][j];

  }

  if(sum>1) isY[i] = false;

  else isY[i] = true;

 }

}

 public boolean isY(int i){

 return isY[i];

}

 

 public boolean checkInfinite(int from, int to) {

 if((to - from) == 1){return true;}

 for(int i = from; i < to; i++){

  if(isY(i)){

   if(fromTo(i)>to){ return false;}

   if(fromTo(i)<from){

    boolean inF = checkInfinite(fromTo(i), to);

    if(inF){return false;}

   }

  } else if(!isY(i)){

   if(fromTo_0(i)>to){ return false;}

   if(fromTo_0(i)<from){

    boolean inF = checkInfinite(fromTo(i), to);

    if(inF){return false;}

   }

   if(fromTo_1(i)>to){ return false;}

  }

 }

 return true;

}

 

 public String findInfiniteLoop(){

 String messageLine="algorithm is correct";

 int nNodes = mConnections.length;

 for(int out = 0; out < nNodes; out++){

  if(!isY(out)) continue;

  for(int in = 0; in < nNodes; in++){

   int current = mConnections[out][in];

   if((current==1)&&(out>in)){

    if(checkInfinite(in, out))

    messageLine = " infinite loop at  "+(out+1);

    return messageLine;

   }

  }

 }  

 return messageLine;

}

 

 public int fromTo(int from){

 int to=0;

 for(int i = 0; i<mConnections.length; i++) {

  if(mConnections[from][i]==1){ to = i+1; break; }

 }

 return to;

}

 

 public int fromTo_1(int from){

 return from+1;

}

 

 public int fromTo_0(int from){

 int to=0;

 for(int i = 0; i<mConnections.length; i++) {

  if((mConnections[from][i]==1)&&(i!=from)){ to = i+1; break; }

 }

 return to;

}

}


 

А также другие работы, которые могут Вас заинтересовать

2629. Руководство по применению стандарта ИСО 9001:2000 в сфере услуг 503.34 KB
  Настоящее справочное пособие (далее для краткости оно именуется просто "Справочник") содержит советы и рекомендации по разработке и документальному оформлению систем менеджмента качества в организациях, занятых в сфере услуг. Справочник подготовлен...
2630. Бизнес-планирование в акционерных обществах энергетики и электрификации 8.57 MB
  Целью написания настоящей книги является оказание практической помощи руководителям и специалистам акционерных обществ энергетики и электрификации (АО-энерго) в составлении бизнес-планов - основного планового документа компаний, функциониру...
2631. Методы нейтрализации(известкование) 309.98 KB
  Умягчение воды - это процесс удаления из воды солей жесткости. Процессы извлечения из воды солей Ca2+ и Mg2+ в водоподготовке называют умягчением воды. Относительно удаление солей жесткости из воды может производиться тремя методами:  реагентны...
2632. Использование средств компьютерных информационных технологий для организации планирования управленческой деятельности 358.34 KB
  Использование компьютерных информационных технологий. Использование компьютерных информационных технологий в деятельности предприятия туристической области. Обоснование выбора набора программных средств для решения...
2633. Исследование теплового режима работы охладителя на тепловых трубах 743.09 KB
  В настоящем отчете представлены результаты экспериментального исследования теплового режима охладителя на тепловых трубах (далее по тексту ТТ). Исследование проводилось на базе оборудования ИС-706. В отчете приведено описание объекта исследования...
2634. Изучение действия магнитного поля на проводник с током 66.81 KB
  Изучение действия магнитного поля на проводник с током Цель работы экспериментальное изучение закона Ампера;  определение  магнитной индукции  в  воздушном  зазоре постоянного магнита. Теоретические осно...
2635. Краткие сведения о погрешности электроизмерительных приборов 32 KB
  Краткие сведения о погрешности электроизмерительных приборов Объектами прямых электрических измерений являются многие электрические и магнитные величины: ток, напряжение, мощность и т.д. Измерение любой физической величины заключается...
2636. Изучение затухающих колебаний 298.5 KB
  Изучение затухающих колебаний Цель работы: изучение электрических собственных колебаний в контуре, содержащем последовательно соединенные катушку с индуктивностью L, конденсатор с емкостью С и резистор с сопротивлением R. Теоретические положения...
2637. Определение емкости конденсатора и батареи конденсаторов 371 KB
  Определение ёмкости конденсатора и батареи конденсаторов  Цель работы: определение ёмкости конденсатора и батареи из двух конденсаторов при их параллельном и последовательном соединении. Описание установки В состав лабораторной установки входят...