这两天,看到各大公司找工作的情况跟要求,准备开始每个星期做点算法小程序
练习一下基础,今天先搞一个字符串左移
原理:
下面是代码:
// StringLeft.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include "string.h"
char * invert(char *start,char *end)
{
char tmp,*ptmp = start;
while (start != NULL &&end != NULL && start < end)
{
tmp = (*start);
(*start) = (*end);
(*end) = tmp;
start++;
end--;
}
return ptmp;
}
char *left(char *s, int pos)
{
int len = strlen(s);
invert(s,s + (pos - 1));
invert(s + pos, s + (len -1));
invert(s, s + (len - 1));
return s;
}
int _tmain()
{
char s[] = "abcdef";//注意字符串常量的问题
///char *s = new char[10];
//s = "abcdef";
//strcmp(s,"abcdef");
printf(s);
printf("
");
left(s,3);
printf(s);
printf("
");
getchar();
return 0;
}
#pragma comment(linker,"/SECTION:.rdata,RW")//加这句可以让常量区可写,后果自负!//赵老师给的编译器设置,测试可以使用,char *s = "abcedf";都能改
上述文章引用了大牛博客的内容: