C 插入';n';printf语句中的制表符
我正在尝试理解使用标准字符串置换算法的递归和回溯C 插入';n';printf语句中的制表符,c,recursion,tabs,printf,C,Recursion,Tabs,Printf,我正在尝试理解使用标准字符串置换算法的递归和回溯(swap-->置换-->swap) 因为我似乎无法理解它是如何回溯、交换字符和排列的,所以我尝试在每次递归的permute()调用中插入printfs,缩进“levels”递增。无论如何,代码如下: void permute(char arr[], int L, int R, int level) { int i = 0; level = level+1; if(L == R) { printf(
(swap-->置换-->swap)
因为我似乎无法理解它是如何回溯、交换字符和排列的,所以我尝试在每次递归的permute()调用中插入printfs,缩进“levels”递增。无论如何,代码如下:
void permute(char arr[], int L, int R, int level)
{
int i = 0;
level = level+1;
if(L == R)
{
printf("%*s", level, "\t");
printf("printing : %s\n", arr);
}
else
{
for(i = L; i <= R; i++)
{
printf("%*s", level, "\t");
printf("swapping %c with %c\n", arr[L], arr[i]);
SWAP(&arr[L], &arr[i]);
permute(arr, L+1, R, level);
printf("%*s", level, "\t");
printf("swapping back %c with %c\n", arr[i], arr[L]);
SWAP(&arr[L], &arr[i]);
}
}
}
int main()
{
char str[] = "abc";
permute(str, 0, 2, 0);
return 0;
}
您知道如何让printf插入
(level*'\t')
选项卡吗?您可以使用for循环:例如
for(int j = 0;j<level;j++)
printf("\t");
for(int j=0;j您可以使用for循环:例如
for(int j = 0;j<level;j++)
printf("\t");
for(int j=0;j格式字符串中的*
不是重复计数;它是最小字段宽度。如果级别
为19,则%*s
将打印19个字符,但字符串中只有一个制表符,因此它将始终只打印一个制表符和18个空格。字符串将右对齐(对于左对齐,没有-
标志),因此将有18个空格和一个制表符
#include <stdio.h>
int main(void)
{
int level = 19;
printf("[%*s]\n", level, "\t");
return 0;
}
在调用printf()之前调用它
格式字符串中的*
不是重复计数;它是最小字段宽度。如果级别
为19,则%*s
将打印19个字符,但字符串中只有一个制表符,因此它将始终只打印一个制表符和18个空格。字符串将右对齐(对于左对齐,没有-
标志),因此将有18个空格和一个制表符
#include <stdio.h>
int main(void)
{
int level = 19;
printf("[%*s]\n", level, "\t");
return 0;
}
在调用printf()
之前调用它
#包括
内部主(空)
{
printf(“我是如何做到这一点的”);
对于(inti=1;i最简单的方法:
#包括
内部主(空)
{
printf(“我是如何做到这一点的”);
对于(int i=1;我可以。但我想知道printf(“%*s”,level,”)
是否适用于制表符。@tcpip:它有效-它不能按您希望的方式工作。我可以。但我想知道printf(“%*s”,level,”)
是否适用于制表符。@tcpip:它有效-它不能按您希望的方式工作。