Автоматическая регулировка разделения элементов для обеспечения равного интервала

Автоматическая регулировка разделения элементов для обеспечения равного интервала

В настоящее время я использую enumitem и создал среду для своих списков в документе. Она следующая:

\newenvironment{alternativas}[1][0]
{
    \begin{enumerate}[label={\Alph*)}, itemsep=#1cm, topsep = 0.5cm, wide=0pt,labelwidth=.5cm,leftmargin=!]
}
{
    \end{enumerate}
}

(хотя я не думаю, что это имеет большое значение для вопроса)

и я искал способ автоматически настроить itemsep, чтобы между всеми элементами было одинаковое расстояние. Вот что янехотим, чтобы произошло:

Из-за дроби, использующей большую высоту, интервал между ABC отличается от интервала между CDE, и это выглядит странно для меня. Мое текущее решение — использовать необязательный параметр в среде, чтобы вручную настроить параметр itemsep и заставить его выглядеть так:

Однако, это медленно для ручной настройки, и мне нужны менее опытные люди, чтобы использовать эту среду. Есть ли способ, чтобы itemsep автоматически устанавливался на самое большое расстояние между элементами? Я много искал и не смог найти (возможно, мой плохой английский не помог). Спасибо!

решение1

Мое предлагаемое решение — измерить высоту и глубину каждого элемента, чтобы получить максимальную высоту и глубину. При необходимости базовый пропуск устанавливается на максимальную высоту плюс максимальная глубина плюс 2pt.

\documentclass{article}
\usepackage{xparse,enumitem,amsmath}

\ExplSyntaxOn

\NewDocumentCommand{\alternatives}{m}
 {
  \blaz_alternativas:n { #1 }
 }

\seq_new:N \l__blaz_alternativas_seq
\box_new:N \l__blaz_alternativas_item_box
\dim_new:N \l__blaz_alternativas_height_dim
\dim_new:N \l__blaz_alternativas_depth_dim

\cs_new_protected:Nn \blaz_alternativas:n
 {
  % first populate the sequence of items
  \seq_set_split:Nnn \l__blaz_alternativas_seq { \\ } { #1 }
  % now measure the heights and depths
  \dim_zero:N \l__blaz_alternativas_height_dim
  \dim_zero:N \l__blaz_alternativas_depth_dim
  \seq_indexed_map_inline:Nn \l__blaz_alternativas_seq
   {
    % set the box to the current item
    \hbox_set:Nn \l__blaz_alternativas_item_box { ##2 }
    % measure the height if not the first item
    \int_compare:nT { ##1 > 1 }
     {
      \dim_set:Nn \l__blaz_alternativas_height_dim
       {
        \dim_max:nn { \l__blaz_alternativas_height_dim }
                    { \box_ht:N \l__blaz_alternativas_item_box }
       }
     }
    % measure the depth if not the last item
    \int_compare:nT { ##1 < \seq_count:N \l__blaz_alternativas_seq }
     {
      \dim_set:Nn \l__blaz_alternativas_depth_dim
       {
        \dim_max:nn { \l__blaz_alternativas_depth_dim }
                    { \box_dp:N \l__blaz_alternativas_item_box }
       }
     }
   }
   \begin{enumerate}[label={\Alph*)},wide=0pt,labelwidth=.5cm,leftmargin=!,itemsep=0pt]
   % set the baselineskip
   \skip_set:Nn \baselineskip
    {
     \dim_max:nn { \baselineskip }
                 { \l__blaz_alternativas_height_dim + \l__blaz_alternativas_depth_dim }
     + 2pt
    }
   % deliver the items
   \seq_map_inline:Nn \l__blaz_alternativas_seq { \item ##1 }
   \end{enumerate}
 }

\ExplSyntaxOff

\begin{document}

\alternatives{ $1$ \\ $2$ \\ $3$ \\ $4$ \\ $5$ }

\alternatives{
  $1$ \\
  $\dfrac{3}{2}$ \\
  $\dfrac{3}{4}$ \\
  $4$ \\
  $5$
}

\end{document}

введите описание изображения здесь

Вот версия, которая добавляет \hphantom{$-$}перед каждым элементом, который не начинается с $-, при условии, что хотя бы один из них начинается с .

\documentclass{article}
\usepackage{xparse,enumitem,amsmath}

\ExplSyntaxOn

\NewDocumentCommand{\alternatives}{m}
 {
  \blaz_alternativas:n { #1 }
 }

\seq_new:N \l__blaz_alternativas_seq
\box_new:N \l__blaz_alternativas_item_box
\dim_new:N \l__blaz_alternativas_height_dim
\dim_new:N \l__blaz_alternativas_depth_dim

\cs_new_protected:Nn \blaz_alternativas:n
 {
  % first populate the sequence of items
  \seq_set_split:Nnn \l__blaz_alternativas_seq { \\ } { #1 }
  % now measure the heights and depths
  \dim_zero:N \l__blaz_alternativas_height_dim
  \dim_zero:N \l__blaz_alternativas_depth_dim
  \seq_indexed_map_inline:Nn \l__blaz_alternativas_seq
   {
    % set the box to the current item
    \hbox_set:Nn \l__blaz_alternativas_item_box { ##2 }
    % measure the height if not the first item
    \int_compare:nT { ##1 > 1 }
     {
      \dim_set:Nn \l__blaz_alternativas_height_dim
       {
        \dim_max:nn { \l__blaz_alternativas_height_dim }
                    { \box_ht:N \l__blaz_alternativas_item_box }
       }
     }
    % measure the depth if not the last item
    \int_compare:nT { ##1 < \seq_count:N \l__blaz_alternativas_seq }
     {
      \dim_set:Nn \l__blaz_alternativas_depth_dim
       {
        \dim_max:nn { \l__blaz_alternativas_depth_dim }
                    { \box_dp:N \l__blaz_alternativas_item_box }
       }
     }
   }
   \begin{enumerate}[label={\Alph*)},wide=0pt,labelwidth=.5cm,leftmargin=!,itemsep=0pt]
   % set the baselineskip
   \skip_set:Nn \baselineskip
    {
     \dim_max:nn { \baselineskip }
                 { \l__blaz_alternativas_height_dim + \l__blaz_alternativas_depth_dim }
     + 2pt
    }
   % check whether some items start with $-
   \cs_set_protected:Nn \__blaz_alternativas_minus:n {##1} % do nothing by default
   \seq_map_inline:Nn \l__blaz_alternativas_seq
    {
     \regex_match:nnT { \A \$\- } { ##1 }
      {
       \seq_map_break:n
        {
         \cs_set_eq:NN \__blaz_alternativas_minus:n \__blaz_alternativas_addminus:n
        }
      }
    }
   % deliver the items
   \seq_map_inline:Nn \l__blaz_alternativas_seq { \item \__blaz_alternativas_minus:n {##1} }
   \end{enumerate}
 }
\cs_new_protected:Nn \__blaz_alternativas_addminus:n
 {
  \regex_match:nnF { \A \$\- } { #1 } { \hphantom{$-$} } #1
 }

\ExplSyntaxOff

\begin{document}

\alternatives{ $1$ \\ $2$ \\ $3$ \\ $4$ \\ $5$ }

\alternatives{
  $-1$ \\
  $-\dfrac{3}{2}$ \\
  $\dfrac{3}{4}$ \\
  $4$ \\
  $5$
}

\end{document}

введите описание изображения здесь

решение2

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

введите описание изображения здесь

\documentclass{article}
\usepackage[column=0]{cellspace}
\setlength\cellspacetoplimit{6pt}
\setlength\cellspacebottomlimit{\cellspacetoplimit}

\usepackage{array,etoolbox}
\preto\tabular{\setcounter{magicrownumbers}{0}}
\newcounter{magicrownumbers}
\newcommand\rownumber{\stepcounter{magicrownumbers}\Alph{magicrownumbers}}
\usepackage{amsmath}

\newenvironment{myalternatives}[1][0]
{\begin{tabular}{@{\makebox[3em][r]{\rownumber)~}}  >{$}0r<{$}}}
{\end{tabular}}

\begin{document}

\begin{myalternatives}
  1 \\
  \dfrac{3}{2} \\
  \dfrac{3}{4} \\
  4 \\
  5 \\
  -6\\
\end{myalternatives}

\end{document} 

Связанный контент