我在用演算法編寫大文本評論時遇到問題。第二個 like 從語句索引的 0 填滿開始。有什麼解決方案可以強制第二條註解行從第一條註解行開始嗎?這是它的樣子。
插入程式碼開始直到問題行。整個程式碼相當大。
\begin{breakablealgorithm}
\caption{Inverse}\label{alg:inverse}
\begin{algorithmic}[1]
\Require Матрица $Z\in \mathbb{Z}_2^{b \times b}$, $S$ - набор неиспользованных столбцов размера $d$, на первой итерации $S$ пуст.
\Ensure $Z^{\dagger}$, требованиям из предыдущей главы, обновленный набор $S$.
\State $p \gets$ \text{тривиальная перестановка для матрицы размера $b$}
\State $d \gets$ Размер перестановки $p$.
\State $ipiv$ \Comment{Перестановка для финального восстановления $Z^{\dagger}$, изначально пуста. Новые элементы перестановки добавляются парами вида (индекс, индекс)}.
\State $D$ \Comment{Массив из пар вида (индекс, Правда/Ложь), необходим для решение системы методов Гаусса в конце алгоритма.}
\State $R \gets Z$
\State В $R$ переставить столбцы и строки с индексами из $S$ в начало матрицы, обновить перестановку $p$, в перестановку $ipiv$ добавить пары с соответствующими значениями.
\State $rank \gets b$ \Comment{Предполагаем, что матрица $R$ полного ранга}
\State \textbf{Цель:} найти разложение $Z = P^T R^T D R P$, где $P$ матрица перестановки, $R$ верхне-треугольная матрица размера $r \times b$ c единичной диагональю, $D$ матрица размера $r \times r$. При этом $D$ --- блочно-диагональная матрица, с блоками на диагонали размера $1 \times 1$ или $2 \times 2$. При этом блоки $2 \times 2$ имеют вид $\begin{array}{c|c} 0 & 1 \\ \hline 1 & 0 \end{array}$ или $\begin{array}{c|c} 0 & 1 \\ \hline 1 & 1 \end{array}$
\State $i \gets 0$
\While{$i < rank$}
\State Рассмотрим i-тую строку матрицы $R$.
\State $j \gets$ Индекс ненулевого элемента в i-ой строке начиная с i-того столбца
\If{$j \ge rank$}
\If{$i < d$} \Comment{В случае, когда строка находится среди строк, которые должны быть выбраны, матрица либо содержит нули, либо неправильной структуры.}
答案1
您可以使用linegoal
, 定義\Longcomment
來容納不適合該行的註解。
這\tpd
技巧是一個古老的技巧,可以確保行與行之間的間距均勻。
我相信這也將與breakablealgorithm
.
請注意多字母變數的處理,例如“rank”。
\documentclass{article}
\usepackage[T2A]{fontenc}
\usepackage[russian]{babel}
\usepackage{amsmath,amssymb}
\usepackage{algorithm,algpseudocode}
\usepackage{linegoal}
\newlength{\commentwidth}
\newlength{\commentcharwidth}
\newcommand{\Longcomment}[1]{%
\settowidth{\commentcharwidth}{$\triangleright$ }%
\setlength{\commentwidth}{\linegoal}%
\addtolength{\commentwidth}{-\commentcharwidth}%
\Comment{\parbox[t]{\commentwidth}{#1\par\xdef\tpd{\the\prevdepth}}}%
\par\nointerlineskip\prevdepth=\tpd
}
\begin{document}
\begin{algorithm}
\caption{Inverse}\label{alg:inverse}
\begin{algorithmic}[1]
\Require Матрица $Z\in \mathbb{Z}_2^{b \times b}$, $S$ - набор неиспользованных
столбцов размера $d$, на первой итерации $S$ пуст.
\Ensure $Z^{\dagger}$, требованиям из предыдущей главы, обновленный набор $S$.
\State $p \gets$ \text{тривиальная перестановка для матрицы размера $b$}
\State $d \gets$ Размер перестановки $p$.
\State $\mathit{ipiv}$
\Longcomment{Перестановка для финального восстановления $Z^{\dagger}$,
изначально пуста. Новые элементы перестановки добавляются парами вида
(индекс, индекс).}
\State $D$
\Longcomment{Массив из пар вида (индекс, Правда/Ложь), необходим для
решение системы методов Гаусса в конце алгоритма.}
\State $R \gets Z$
\State В $R$ переставить столбцы и строки с индексами из $S$ в начало
матрицы, обновить перестановку $p$, в перестановку $ipiv$ добавить
пары с соответствующими значениями.
\State $\mathit{rank} \gets b$ \Comment{Предполагаем, что матрица $R$ полного ранга}
\State \textbf{Цель:} найти разложение $Z = P^T R^T D R P$, где $P$ матрица
перестановки, $R$ верхне-треугольная матрица размера $r \times b$ c
единичной диагональю, $D$ матрица размера $r \times r$.
При этом $D$ --- блочно-диагональная матрица, с блоками на диагонали
размера $1 \times 1$ или $2 \times 2$. При этом блоки $2 \times 2$
имеют вид $\begin{array}{c|c} 0 & 1 \\ \hline 1 & 0 \end{array}$
или $\begin{array}{c|c} 0 & 1 \\ \hline 1 & 1 \end{array}$
\State $i \gets 0$
\While{$i < \mathit{rank}$}
\State Рассмотрим i-тую строку матрицы $R$.
\State $j \gets$ Индекс ненулевого элемента в i-ой строке начиная с i-того столбца
\If{$j \ge \mathit{rank}$}
\If{$i < d$}
\Longcomment{В случае, когда строка находится среди строк, которые
должны быть выбраны, матрица либо содержит нули, либо
неправильной структуры.}
\EndIf
\EndIf
\EndWhile
\end{algorithmic}
\end{algorithm}
\end{document}