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;

}

}


 

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

5002. Правовые и профессионально-этические регуляторы в журналистике 185.5 KB
  Правовые и профессионально-этические регуляторы в журналистике Введение Средства массовой информации и коммуникации часто вызывают полемику в обществе. Вопросы массовых коммуникаций важны потому, что прямо или косвенно оказывают влияние на жизни люд...
5004. Передняя подвеска автомобиля ГАЗ-53А 205.2 KB
  Передняя подвеска автомобиля ГАЗ-53А (L=1450 мм) Введение Перед автомобильной промышленностью в настоящее время стоят задачи, связанные с увеличением выпуска экономичных автомобилей с дизельными двигателями, позволяющих значительно сократить расход ...
5005. Выбор системы автоматического управления сверлильно-расточно-фрезерного станка модели 600V 100 KB
  Выбрать систему автоматического управления сверлильно-расточно-фрезерного станка модели 600V, проспект Стерлитамакского станкостроительного завода прилагается. Список сокращений САУ – система автоматического управления УЧПУ...
5006. Проект геодезического обоснования стереотопографической съемки масштаба 1:5000 302 KB
  Топографические карты, созданные в результате обработки данных топографической съемки, используют в различных областях человеческой деятельности. Без карт невозможна работа по прокладке нефтепроводов и газопроводов, строительству электрост...
5007. Экономическая система: понятие, структура, генезис 180 KB
  Экономическая система есть совокупность взаимосвязанных и определенным образом упорядоченных элементов экономики, образующих экономическую структуру общества. Вне системного характера экономики не могли бы воспроизводиться (постоянно возоб...
5008. Анализ стилевых особенностей и имиджа менеджера 309 KB
  Общество представляет собой сложную, многоуровневую, целостную и динамически развивающуюся систему. Неотъемлемым атрибутом любой системы – является управление, которое обеспечивает ее сохранение и развитие, упорядочение структуры, взаи...
5009. Возможности использования в российских условиях зарубежного опыта управления предприятием, организацией, фирмой 148.5 KB
  Возможности использования в российских условиях зарубежного опыта управления предприятием, организацией, фирмой. Теория и практика менеджмента получили широкое применение в развитых странах. В США доля менеджеров различных уровней в общей...
5010. Элементы квантовой теории. Основы атомной и ядерной физики 516.5 KB
  Введение В сборнике представлены тестовые задания закрытого типа и на соответствие по разделам Элементы квантовой теории, Основы атомной и ядерной физики, предназначенные для аудиторной и внеаудиторной самостоятельной работы студентов. Тестовые за...