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;

}

}


 

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

78732. Построение графа цепи для метода узловых напряжений 907.5 KB
  Построить граф цепи для метода узловых напряжений Жирным выделенны узлы Курсивом – ветки Матрица инцеденций Расчет токов методом узловых напряжений Матрицы сопротивлений, индуктивностей и источников ЭДС. Порядковый номер строки которых, соответствуют порядковому номеру веток графа (см. пункт 4).
78734. Свято до Дня української писемності 338.5 KB
  Преподобний Нестор-літописець – киянин, у сімнадцять років прийшов у Києво-Печерську лавру послушником. Прийняв його сам засновник монастиря преподобний Феодосій. Молитвою та послухом юний подвижник невдовзі перевершив найвидатніших старців.
78735. Свято врожаю (6-7 класи) 395.5 KB
  Творці небувалого світлого дня Хай поле врожайнеє вам піснею буде Братихлібороби моя рідня. Розстелемо тут рушничок покладемо окраєць хліба й дрібок солі. Кожен колос зерном налитий Кожен колос зерном налитий Борода наша пишна Оце тобі борода хліб сіль і вода. Хліб.
78736. Андріївські вечорниці 73 KB
  Андрія Первозванного або, як у народі називають, свято Калити. Народні традиції міцно переплелися з релігійними та отак і дійшли до наших днів. Вечір напередодні молодь святкувала як «андріївські вечорниці». Готувались до них у складчину. До однієї господині зносили борошно, крупу, сушені яблука та груші й готували пісну вечерю.
78737. ВИХОВНИЙ ЗАХІД «СВЯТО БУКВАРЯ» 42.5 KB
  Сценарій заходу Свято Букваря Вчитель. Увага увага Любі гості мами й тата В нас Букварикове свято Добре що прийшли до нас Ви у перший клас. Ось і дзвіночок веселий кличе завзято Першокласників на свято.