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;

}

}


 

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

3631. Теория с вычислительных процессов 63.5 KB
  Процессы. Параллельные процессы. Последовательные процессы Цель работы: Усвоить понятие процесса. Изучить виды процессов и способы их взаимодействия. Рекомендации по выполнению работы 1. проработать материал лекции 9-14 2. При оформлении выполненног...
3632. Экономические последствия чрезвычайных ситуаций 131 KB
  Экономические аспекты безопасности жизнедеятельности В связи с ухудшением техногенной обстановки в России можно ожидать, что во многих случаях отдельные, даже небольшие по своим масштабам производственные аварии и стихийные бедствия станут одной цеп...
3633. Анализ финансового положения предприятия 82 KB
  Анализом хозяйственной деятельности называется научно разработанная система методов и приемов, посредством которых изучается экономика предприятия, выявляются резервы производства на основе учетных и отчетных данных, разрабатываются пути их...
3634. Экономическое содержание категории предприятие 61 KB
  Понятие и экономическое содержание категории «предприятие». Классификация предприятий. В современной экономике производство организуется в форме предприятия. Поэтому предприятие является основным элементом экономической системы, а уровень использ...
3635. Філософія доби Відродження 95.5 KB
  Історичні передумови Відродження Історичний період, до розгляду філософії якого ми приступаємо, у сучасників одержав назву «Відродження» (від фр. «Renaissance» - Ренесанс) оскільки в їх час було відроджено ту культуру, яку знищило було християнство ...
3636. Основы менеджмента. Курс лекций 541.5 KB
  Тема Исторические основы менеджмента Условия и факторы возникновения и развития менеджмента. Этапы и школы в истории менеджмента. Влияние национально-исторических факторов на развитие менеджмента. Перспективы менеджмента в России. Усл...
3637. Правовые характеристики правового принуждения 91 KB
  Управление обществом, обеспечение общественной дисциплины и правопорядка осуществляется с помощь активных способов целенаправленного воздействия на сознание и поведение людей, в качестве этих способов выступают и такие методы государственно...
3638. Возникновение социологии как науки 86.5 KB
  Возникновение социологии как науки приходится на 1830-е года., хотя Попытки социологического анализа проблем общественной жизни предпринимались и раньше. Их наличие дает основание усматривать «начало» социологии одним авторам в древности, связывая...
3639. Изучение системы Паблик Рилейшнз используемой предприятием и определение рекомендаций по ее совершенствованию 539.5 KB
  Введение Термин «Паблик Рилейшнз» получил широкое распространение в сферах, связанных с менеджментом и маркетингом в развитых странах в начале 1970-х годов. Его буквальное значение – «отношение с общественностью». Деятельность по Паблик Рилейшн...