由两个绝对路径来推出相对路径
先给出两个绝对路径
c./test/abc/haha/123/tom.doc
c./test/abc/123/hehe/
来推出如下的相对路径
…/…/haha/123/tom.doc
代码:
#include<stdio.h>
#include<string.h>
int main()
{
char dir[] = "c./test/abc/haha/123/tom.doc";
char cur[] = "c./test/abc/123/hehe/";
char dir2[100] = {""};
int i=0, j=0,k=0,d=0;
while (dir[i]==cur[i])
{
i++;
}
d = i;
while (cur[i])
{
if (cur[i++] == '/')
j++;
}
for (k = 0; k < j*3; k++)
{
if ((k + 1) % 3 == 0)
{
dir2[k] = '/';
}
else dir2[k] = '.';
}
while (dir[d])
{
dir2[k++] = dir[d++];
}
puts(dir2);
return 0;
}
主要思想是:先定义三个字符串,前两个字符串中存放着绝对路径,第三个字符串是个有足够大存储空间的空字符串。
先遍历前两个字符串,找到目标路径与当前路径中相同的路径,由一个变量i来记录,找到不同时终止遍历,并记住i的值,再在当前路径的字符串中从i开始遍历,找到不同的路径中有几个’/’。
由于有一个‘/’就要输出“…/”即找到一个‘/’输出"…/"总共看可以找到几个’/’,假定找到j个’/‘则要给定义的空字符串中的前3*k个空间赋值,我使用了一个for循环,循环变量k从0开始如果(k+1)%3=0,则说明应输入‘/’,如果(k+1)%3!=0,则说明应该输入的是’.’;由此可以将相对路径前面的“…/”全部输入到字符串中。
由于i值记录的是目标路径与当前路径第一个不同字符的下标,所以我们可以从i开始对目标字符串进行遍历,将i到‘\0’的所有字符全部赋给第三个字符串。
最终,第三个字符串就是我们要找的相对路径。
九九乘法表
代码:
#include<stdio.h>
#include<math.h>
int main()
{
int i ,j;
for (i=1; i <= 9; i++)
{
for (j=1; j <=i; j++)
{
printf("%d*%d=%-5d",j,i,i*j);
}
puts("");
}
return 0;
}
运行结果