程序片段(01):加法.c

内容概要:字符串计算表达式

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h> //01.去除空格:
// 1.空格:空格+Tab键+相似符...
// 2.双索引+双指针
// 变化快+变化慢:变化快覆盖变化慢
void removeBlankSpaceByIndex(char * pStr)
{//双索引
int i = 0;
int j = 0;
//while ('\0' != *(pStr + j))
//{
// *(pStr + i) = *(pStr + j);
// if (' ' != *(pStr + i))
// {
// ++i;//补位|缺位-->替换|不替换
// }
// ++j;
//}
//*(pStr + i) = '\0';//又一次标识结束
while ('\0' != (*(pStr + i) = *(pStr + j++)))
{
if (' ' != *(pStr + i))
{//控制移位
++i;
}
}
} void removeBlankSpaceByPoint(char * pStr)
{//双指针
char * p1 = pStr;
char * p2 = pStr;
//while ('\0' != *p2)
//{
// *p1 = *p2;
// if (' ' != *p1)
// {
// ++p1;
// }
// ++p2;
//}
//*p1 = '\0';
while ('\0' != (*p1 = *p2++))
{
if (' ' != *p1)
{
++p1;
}
}
} int isNum(char chr)
{
if ('0' <= chr && chr <= '9')
{
return 1;
}
return 0;
} //02.数据提取法:
//整数提取法:
// mutiple:0----->10----->100
// int:x----->xy----->xyz
// value=int*10:先升位
// value=value+num:后补位
//小数提取法:
// mutiple:0.1--->0.01--->0.001
// double:0.x--->0.xy--->0.xyz
// value= value+mutiple*num
double getNum(char * pStr, int * pIndex)
{
double dbInt = 0.0;
int index = *pIndex;
while (isNum(*(pStr + index)))
{//整数部分
dbInt = dbInt * 10 + *(pStr + index) - '0';
++index;
}
if ('.' == *(pStr + index))
{
double dbDouble = 1.0;
while (isNum(*(pStr + (++index))))
{//小数部分
dbDouble /= 10;
dbInt += dbInt + dbDouble * (*(pStr + index) - '0');
}
}
*pIndex = index;
return dbInt;
} //03.核心控制计算:
double caculate(char * pStr)
{
double value = 0.0;
int index = 0;
value = getNum(pStr, &index);
while (1)
{
char op = *(pStr + index);
++index;
switch (op)
{
case '\0':
{
return value;
break;
}
case '+':
{
value += getNum(pStr, &index);
break;
}
case '-':
{
value -= getNum(pStr, &index);
break;
}
default:
break;
}
}
return value;
} //04.常量表达式递归解析:
// 1.运算符优先级结合性
// 2.树状结构模拟计算流
// 3.严格控制计算顺序流
int main01(void)
{
char str[1024] = { 0 };
scanf("%[^\n]", str);
printf("待计算的常量表达式为:%s \n", str);
//removeBlankSpaceByIndex(str);
removeBlankSpaceByPoint(str);
printf("经过预处理后的常量表达式为:%s \n", str); int index = 0;
double value = getNum(str, &index);
printf("第一个获取的数据为:%lf \n", value);
printf("该常量表达式的计算结果为:%lf \n", caculate(str)); system("pause");
}

程序片段(02):乘除法.c

内容概要:乘除法

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h> void removeBlankSpace(char * pStr)
{
char * p1 = pStr;
char * p2 = pStr;
while ('\0' != (*p1 = *p2++))
{
if (' ' != *p1)
{
++p1;
}
}
} int isNum(char chr)
{
if ('0' <= chr && chr <= '9')
{
return 1;
}
return 0;
} double getNum(char * pStr, int * pIndex)
{
double dbInt = 0;
int index = *pIndex;
while (isNum(*(pStr + index)))
{
dbInt += dbInt * 10 + (*(pStr + index) - '0');
++index;
}
if ('.' == *(pStr + index))
{
double dbDouble = 1.0;
while (isNum(*(pStr + (++index))))
{
dbDouble /= 10;
dbInt += dbDouble*(*(pStr + index) - '0');
}
}
*pIndex = index;
return dbInt;
} double caculateMulDiv(char * pStr, int * pIndex)
{
double value = 0.0;
value = getNum(pStr, pIndex);
while (1)
{
if ('*' == *(pStr + *pIndex))
{
(*pIndex)++;
value *= getNum(pStr, pIndex);
}
else if ('/' == *(pStr + *pIndex))
{
(*pIndex)++;
value /= getNum(pStr, pIndex);
}
else
{
break;
}
}
return value;
} double caculateAddSub(char * pStr)
{
double value = 0.0;
int index = 0;
value = caculateMulDiv(pStr, &index);
while (1)
{
char op = *(pStr + index);
++index;
switch (op)
{
case '\0':
{
return value;
}
case '+':
{
value += caculateMulDiv(pStr, &index);
break;
}
case '-':
{
value -= caculateMulDiv(pStr, &index);
break;
}
default:
break;
}
}
return value;
} int main01(void)
{
char str[1024] = { 0 };
scanf("%[^\n]", str);
printf("待计算的常量表达式为:%s \n", str);
removeBlankSpace(str);
printf("经过预处理之后的常量表达式为:%s \n", str);
//int index = 0;
//double value = getNum(str, &index);
//printf("第一个获取到的数据为:%lf \n", value);
printf("常量表达式的计算结果为:%lf \n", caculateAddSub(str)); system("pause");
}

程序片段(03):括号.c

内容概要:括号

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h> void removeBlankSpace(char * pStr)
{
char * p1 = pStr;
char * p2 = pStr;
while ('\0' != (*p1 = *p2++))
{
if (' ' != *p1)
{
p1;
}
}
} int isNum(char chr)
{
if ('0' <= chr && chr <= '9')
{
return 1;
}
return 0;
} double getNum(char * pStr, int * pIndex)
{
double dbInt = 0;
int index = *pIndex;
while ('(' == *(pStr + index))
{
char * pSubStr = NULL;
*pIndex += ++index;
pSubStr = caculateParenthese(pStr, pIndex);
double caculateAddSub(char * pstr);
dbInt = caculateAddSub(pSubStr);
free(pSubStr);
pSubStr = NULL;
return dbInt;
} while (isNum(*pStr + index))
{
dbInt = dbInt * 10 + (*(pStr + index) - '0');
++index;
} if ('.' == *(pStr + index))
{
double dbDouble = 1.0;
while (isNum(*(pStr + (++index))))
{
dbDouble /= 10;
dbInt = dbDouble * (*(pStr + index) - '0');
}
}
*pIndex = index;
return dbInt;
} char * caculateParenthese(char * pStr, int * pIndex)
{
char * tmpStr = NULL;
int num = 0;//括号对数
int leftIndex = *pIndex;//左索引位置
do
{
switch (*(pStr + *pIndex))
{
case '(':
{
++num;
break;
}
case ')':
{
if (0 == num)
{
++(*pIndex);
tmpStr = (char *)malloc((*pIndex - leftIndex) * sizeof(char));
strncpy_s(tmpStr, *pIndex - leftIndex, pStr + leftIndex, *pIndex - leftIndex - 1);
printf("%s \n", tmpStr);
return tmpStr;
}
else
{
--num;
}
break;
}
}
} while ('\0' != *(pStr + (*pIndex)++));
} double caculateMulDiv(char * pStr, int * pIndex)
{
double value = 0.0;
value = getNum(pStr, pIndex);
while (1)
{
if ('*' == *(pStr + *pIndex))
{
++(*pIndex);
value *= getNum(pStr, pIndex);
}
else if ('/' == *(pStr = *pIndex))
{
++(*pIndex);
value /= getNum(pStr, pIndex);
}
else
{
break;
}
}
return value;
} double caculateAddSub(char * pStr)
{
double value = 0.0;
int index = 0;
value = caculateMulDiv(pStr, &index);
while (1)
{
char op = *(pStr + index);
++index;
switch (op)
{
case '\0':
return value;
case '+':
{
value += caculateMulDiv(pStr, &index);
break;
}
case '-':
{
value += caculateMulDiv(pStr, &index);
break;
}
default:
break;
}
}
} //01.常量表达式计算流程:
// 加减法-->乘除法-->小括号
int main(void)
{
char str[1024] = { 0 };
scanf("%[^\n]", str);
removeBlankSpace(str);
printf("%lf \n", caculateAddSub(str)); system("pause");
}

程序片段(04):DelStr.c

内容概要:删除指定字符串

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <locale.h> //删除首个指定字符
void delFirstChrByIndex(char * pStr, char chr)
{
char * p = strchr(pStr, chr);
if (NULL == p)
{
return;
}
for (int i = 0; i < strlen(p); ++i)
{
*(p + i) = *(p + i + 1);
}
} void delFirstChrByPoint(char * pStr, char chr)
{
char * p = strchr(pStr, chr);
if (NULL == p)
{
return;
}
char * p1 = p;
char * p2 = p + 1;
//while ('\0' != *p1)
//{
// *p1 = *p2;
// ++p2;
// ++p1;
//}
//while (*p1)//*p1<=>*p1!=0<=>*p1!='\0'
//{
// *p1 = *p2;
// ++p2;
// ++p1;
//}
//while (*p1++ = *p2++);
//while (*p1 = *(p1++ + 1));
} //删除同样指定字符
void delAllChrByIndex(char * pStr, char chr)
{
int i = 0;
int j = 0;
while ('\0' != *(pStr + i))
{
*(pStr + i) = *(pStr + j);
if (chr != *(pStr + i))
{
++i;
}
++j;
}
} void delAllChrByPoint(char * pStr, char chr)
{
char * p1 = pStr;
char * p2 = pStr;
//while ('\0' != *p1)
//{
// *p1 = *p2;
// if (chr != *p1)
// {
// ++p1;
// }
// ++p2;
//}
while ('\0' != (*p1 = *p2++))
{
*p1 = *p2;
if (chr != *p1)
{
++p1;
}
}
} //删除首个指定字符串
void delFirstStrByIndex(char * pStr, char * pSubStr)
{
char * p = strstr(pStr, pSubStr);
if (NULL == p)
{
return;
}
int pLen = strlen(p);
int subStrLen = strlen(pSubStr);
int validLen = pLen - subStrLen;
for (int i = 0; i <= validLen; ++i)
{
*(p + i) = *(p + i + subStrLen);
}
} void delFirstStrByPoint(char * pStr, char * pSubStr)
{
char * p = strstr(pStr, pSubStr);
if (NULL == p)
{
return;
}
int subStrLen = strlen(pSubStr);
char * p1 = p;
char * p2 = p + subStrLen;
//while ('\0' != *p1)
//{
// *p1 = *p2;
// ++p2;
// ++p1;
//}
//while ('\0' != (*p1 = *p2))
//{
// ++p2;
// ++p1;
//}
//while ('\0' != (*p1++ = *p2++));
while ('\0' != (*p1 = *(p1++ + subStrLen)));
} //删除同样字符串
void delAllStrByIndex(char * pStr, char * pSubStr)
{
int i = 0;
int j = 0;
int subStrLen = strlen(pSubStr);
while ('\0' != (*(pStr + i) = *(pStr + j)))
{
int flag = 1;
for (int k = 0; k < subStrLen; ++k)
{
if ('\0' == *(pStr + j + k) || *(pStr + j + k) != *(pSubStr + k))
{
flag = 0;
break;
}
}
if (!flag)
{
++j;
++i;
}
else
{
j += strlen(pSubStr);
}
}
} void delAllStrByPoint(char * pStr, char * pSubStr)
{
char * p1 = pStr;
char * p2 = pStr;
while ('\0' != (*p1 = *p2))
{
int flag = 1;
char * px = p2;
char * py = pSubStr;
while ('\0' != *py)
{
if ('\0' == *px || *px != *py)
{
flag = 0;
break;
}
++px;
++py;
}
if (!flag)
{
++p1;
++p2;
}
else
{
p2 += strlen(pSubStr);
}
}
} int main01(void)
{
char str[1024] = "i love china i love you i love money i love girl";
printf("%s \n", str);
//delFirstChrByIndex(str, 'i');
//delFirstChrByPoint(str, 'i');
//delAllChrByIndex(str, 'i');
//delAllChrByPoint(str, 'i');
//delFirstStrByIndex(str, "love");
//delFirstStrByPoint(str, "love");
//delAllStrByIndex(str, "love");
//delAllStrByPoint(str, "love");
printf("%s \n", str); system("pause");
} void delAllWStrByPoint(wchar_t * pWStr, wchar_t * pSubWStr)
{
wchar_t * p1 = pWStr;
wchar_t * p2 = pWStr;
while (L'\0' != (*p1 = *p2))
{
int flag = 1;
wchar_t * px = p2;
wchar_t * py = pSubWStr;
while (L'\0' != *pSubWStr)
{
if (L'\0' == *px || *px != *py)
{
flag = 0;
break;
}
++px;
++py;
}
if (!flag)
{
++p1;
++p2;
}
else
{
p2 += wcslen(pSubWStr);
}
}
} //01.连接较长字符串:
// 1.单行法
// 2.反斜杠(结尾)
int main02(void)
{
//wchar_t wstr[1024] = "上联:试问中国男足几多愁. 下联:恰似一群太监上青楼. 横联:无人能射上联:再问中国男足几多愁.下联:恰似一群妓女守青楼.横联:总是被射上联:三问中国男足几多愁.下联:恰似阳痿患者逛青楼.横联 : 欲射不能 上联:四问中国男足几多愁.下联:恰似一群小孩上青楼.横联 : 尚不能射上联:五问中国男足几多愁.下联:恰似一群傻瓜去青楼.横联 : 往哪里射上联:六问中国男足几多愁.下联:恰似跑堂杂役在青楼.横批 : 看别人射love love love love love love love love中国队要是能进球,我就投案自首。--拉登 中国队要是能进球,我就停止核武器!--内贾德中国队要是能进球,我就改革开放! --金三胖中国队要是能进球,我就把靖国神社拆了!--小泉纯一郎中国队要是能进球。我就认拉灯当干爹!--布什 中国队要是能进球,我就信佛。--上帝中国队要是能进球,我就信上帝! --释迦牟尼中国队要是能进球。我就回归!--阿扁中国队要是能进球。我立即复活--阿拉法特 中国队要是能进球。我们就辞职。--中国足协最后说中国队要是能进球, 我就倒着转!--地球说 中国对要是能进球, 我就从西边出来!--太阳说 中国对要是能进球, 我就去给猫当伴娘!--耗子说 中国对要是能进球, 我就再爆炸一次!-宇宙最后说 ";
//"\"起到连接的作用,当做总体分行
setlocale(LC_ALL, "zh-CN");
wchar_t wstr[1024] = L"上联:试问中国男足几多愁. 下联:恰似一群太监上青楼. 横联:无人能射\
上联:再问中国男足几多愁.下联:恰似一群妓女守青楼.横联:总是被射 \
上联:三问中国男足几多愁.下联:恰似阳痿患者逛青楼.横联 : 欲射不能\
上联:四问中国男足几多愁.下联:恰似一群小孩上青楼.横联 : 尚不能射\
上联:五问中国男足几多愁.下联:恰似一群傻瓜去青楼.横联 : 往哪里射\
上联:六问中国男足几多愁.下联:恰似跑堂杂役在青楼.横批 : 看别人射\
love love love love love love love love\
中国队要是能进球,我就投案自首! --拉登\
中国队要是能进球,我就停止核武器!--内贾德\
中国队要是能进球,我就改革开放。--金三胖\
中国队要是能进球,我就把靖国神社拆了! --小泉纯一郎\
中国队要是能进球,我就认拉灯当干爹! --布什\
中国队要是能进球,我就信佛。--上帝\
中国队要是能进球。我就信上帝!--释迦牟尼\
中国队要是能进球,我就回归。--阿扁\
中国队要是能进球,我立即复活--阿拉法特\
中国队要是能进球,我们就辞职。--中国足协最后说\
中国队要是能进球, 我就倒着转!--地球说\
中国对要是能进球, 我就从西边出来!--太阳说\
中国对要是能进球, 我就去给猫当伴娘!--耗子说\
中国对要是能进球, 我就再爆炸一次!-宇宙最后说 ";
wchar_t str[10] = L"中国";
delAllWStrByPoint(wstr, str);
wprintf(L"%ls", wstr); system("pause");
}

程序片段(05):01.字符串分割以及动态分配.c+02.strtok.c

内容概要:字符串分割以及字典

///01.字符串分割以及动态分配.c
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h> //01.C语言没有空字符!
// 注:没有('')的说法
//02.字符串操作:
// 分割+字典
//03.strtok原理:
// 1.内存替换指定字符为'\0'
// 2.内存分割到'\0'
int getChrCount(char * pStr, char chr)
{
if (NULL == pStr)
{
return -1;
}
int i = 0;
for (char * p = strchr(pStr, chr); NULL != p; p = strchr(p + 1, chr))
{
++i;
}
return i;
} void removeBlankSpace(char * pStr, char chr)
{
char * p1 = pStr;
char * p2 = pStr;
while (*p1 = *p2)
{
if (chr != *p1)
{
++p1;
}
++p2;
}
} //04.单个字符串:
// 1.总体存储
// 2.多行显示
//注:须要使用反斜杠('\')标识
int main01(void)
{
char str[2048] = "我们还是当朋友好了 ( 事实上你还有能够利用的价值)\
我想我真的不适合你 ( 我根本就不喜欢你!)\
事实上你人真的非常好 ( 但是我不想和你在一起)\
你人真的非常好 ( 我是真的不想和你在一起)\
你人真的真的非常好....真的 ( 猪头, 离我远一点!)\
我暂时不想交男朋友 ( 闪边啦!你还不到我心中帅哥标准的一半)\
我不想伤害我们之间的友谊 ( 我们之间也仅仅会有友谊)\
我心中牵挂着一个人 ( 那个人是我专门为你这种人虚构的)\
我从来没想过这个问题 ( 这是根本不可能的.还用想吗 ? )\
我不适合当个情人 ( 废话, 没人会适合当你的情人的)\
你给我一段时间考虑 ( 不给我时间, 我怎么溜啊)\
你的条件真的非常好 ( 但是还没好到我想要的地步)\
但是这种感觉好怪 ( 你这丑八怪, 怪到这样还想吃天鹅肉 ? )\
你的温和我会铭记在心的 ( 拜托, 情圣!光温和是无用的, 还要有钱!)\
事实上我一直没勇气接受你( 看到你差点吓死, 哪还有勇气 ? )\
你真的非常可爱 ( 你真的非常幼稚)\
你真的是超级可爱啦 ( 猪头, 不要象小孩那样缠着我!)\
遇到你, 总会让我重温童年的快乐 ( 就象阿姨遇到小弟弟那样)\
我们应该给彼此一点缓冲时间 ( 给你时间快滚, 再不走我要翻脸啦!)\
别人都说你条件不错啊 ( 可我从来没这样觉得!)\
假设我们早点认识就好了 ( 能够让你早点觉悟!)\
别急嘛, 我们能够做朋友 ( 趁这个时候我要找到我的白马王子啊~)\
";
int num = getChrCount(str, ')');
printf("该字符串一共存在%d行! \n", num); char ** strAll = (char **)malloc(num * sizeof(char *));
char ** strSay = (char **)malloc(num * sizeof(char *));
char ** strThink = (char **)malloc(num * sizeof(char *));
int i = 0;
for (char * p = strtok(str, ")"); NULL != p; p = strtok(p + strlen(p) + 1, ")"))
{
if (i < num)
{
*(strAll + i) = (char *)malloc((strlen(p) + 1) * sizeof(char));
strcpy(*(strAll + i), p);
//removeBlankSpace(*(strAll + i), '\t');
//printf("%s \n", *(strAll + i));
}
++i;
}
for (int i = 0; i < num; ++i)
{
char * pStr = *(strAll + i);
pStr = strtok(pStr, "(");
*(strSay + i) = (char *)malloc((strlen(pStr) + 1)*sizeof(char));
strcpy(*(strSay + i), pStr);
pStr = pStr + strlen(pStr) + 1;
*(strThink + i) = (char *)malloc((strlen(pStr) + 1)*sizeof(char));
strcpy(*(strThink + i), pStr);
} char myStr[128] = { 0 };
scanf("%s", myStr); int flag = 0;
for (int i = 0; i < num; ++i)
{
char * p = strstr(strSay[i], myStr);
if (NULL != p)
{
flag = 1;
printf("说的是:%s,想的却是:%s \n", strSay[i], strThink[i]);
break;
}
}
if (!flag)
{
printf("能够问芳姐! \n");
} system("pause");
}
///02.strtok.c
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h> //01.strtok原理:
// 1.内存替换('\0')
// 2.内存返回首地址
//注:不宜字符串常量池
char * myStrTok(char * pStr, char * pSplit)
{
char * p = strstr(pStr, pSplit);
if (NULL != p)
{
*p = '\0';
return pStr;
}
return NULL;
} int main(void)
{
//char * str = "123,qwer,thjk,qsdf";//strtok不适合常量
char str[100] = "123,qwer,thjk,qsdf";
for (char * p = myStrTok(str, ","); NULL != p; p = myStrTok(p + strlen(p) + 1, ","))
{
printf("%s \n", p);
} char * p = strtok(str, ",");//strtok:传递字符串进行分割
//替换为('\0')
printf("%s \n", p);
for (int i = 0; i < 100; ++i)
{
printf("%d, %c \n", *(str + i), *(str + i));
} system("pause");
}

程序片段(06):scanfsprintf.c

内容概要:字符串获取打印sscanfsprintf

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h> //01.对字符串扫描打印:
// 字符串扫描:sscanf(str, 格式字符串, 地址列表);
// 跨函数改动内存-->地址列表(改动原本)
// 字符串打印:sprintf(str, 格式字符串, 内存列表);
// 跨函数读取内存-->内存列表(读取副本)
//注:分为直接解析(普通变量)和间接解析(指针变量)
//02.strtol();(数值/单位)函数
// char * unit;
// long price = strtol(str, &unit, 10);
// 依照指定进制数;从待读取字符串起始位置往后进行读取,遇到非数字字符结束读取状态
// 并将非数字字符的位置给记录下来
int main01(void)
{
char str[1024] = "124784 # T小姐 # 女 # 22# 168 #在校学生 # 10000元/天 # 北京电影学院学生,形象气质佳,可爱高雅有品位,出身良好,富有才情和浪漫,英语非常流利,喜欢旅游,常去欧洲度假,仅仅针对高端有实力客户,不接收不论什么陌生来电,发短信就可以。北京1W每次,外地另议。 接受价格再与我联系,无实力者勿扰。不要浪费彼此时间,切记! # 18600959828 # 1002823878@qq.com # 2289557521";
for (int i = 0; i < strlen(str); ++i)
{//字符串预处理
if ('#' == *(str + i))
{
*(str + i) = ' ';
}
} int id;
char name[10];
char gender[10];
int age;
int height;
char identity[10];
char price[100];
char introduce[500];
long long telephone;
char email[100];
long long QQ;
sscanf(str, "%d%s%s%d%d%s%s%s%lld%s%lld", &id, name, gender, &age, &height, identity, price, introduce, &telephone, email, &QQ);
//printf("id:%d, name:%s, gender:%s, age:%d, height:%d, identity:%s, price:%s, introduce:%s, telephone:%lld, email:%s, QQ:%lld \n", id, name, gender, age, height, identity, price, introduce, telephone, email, QQ); char * pos;
int cost = strtol(price, &pos, 10);//strtol:从前往后读取整数,遇到非数字终止,10代表十进制读取方式
printf("cost:%d, pos:%s \n", cost, pos);//pos的值为找到的第一个非数字的字符指针
//
//char newStr[1000];
//sprintf(newStr, "编号为%d, 名字为%s, 性别为%s, 年龄为%d, 身高为%d %s%s%s%lld%s%lld \n", id, name, gender, age, height, identity, price, introduce, telephone, email, QQ);
//printf("%s \n", newStr); system("pause");
}

程序片段(07):01.strdup.c+02.strerror.c+03.strncpy.c+04.strpbrk.c+05.strrchr.c+06.strrev.c+07.strspn.c

内容概要:字符串经常使用函数

///01.strdup.c
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h> char * myStrDup(char * pStr)
{
char * p = (char *)malloc((strlen(pStr) + 1)*sizeof(char));
strcpy(p, pStr);
return p;
} //01.strdup();(类strcpy)函数:
// 格式:char * p = strdup(str);
// 原理:为字符指针变量p2分配字符串存储空间;
// 将字符串str的全部字符内容复制到分配的存储空间其中
//注:注意该拷贝后的字符串位于堆内存,须要手动进行回收
int main01(void)
{
char * p1 = NULL;
char * p2 = "calc";
//*p2 = 'A';
p1 = _strdup(p2);
printf("p1:%s \n", p1);
free(p1); system("pause");
}
///02.strerror.c
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>//採用预置宏定义error //01.strerror();(字符串错误)函数
// 格式:char * errorInfo = strerror(errno);
// 原理:一旦发生字符串相关错误,strerror(errno);就能检測到字符串错误
// 而且返回字符串的错误相关信息
int main02(void)
{
char * errorInfo = strerror(errno);
printf("errorInfo:%s \n", errorInfo); system("pause");
}
///03.strncpy.c
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h> char * myStrNCpy(char * pDest, char * pSrc, int maxLen)
{
if (NULL == pDest || NULL == pSrc)
{
return NULL;
}
char * pTemp = pDest;
for (int i = 0; i < maxLen; ++i)
{
*(pTemp + i) = *(pSrc + i);
}
return pDest;
} //01.strncpy();(指定字符数拷贝)
// 格式:char * strncpy(char * destin, char * source, int maxLen);
// 原理:从源字符串其中拷贝指定长度的字符序列到目标字符指针位置
//注:没有涉及到暂时缓冲区问题,是一个一个的映射关系
int main03(void)
{
char str[10] = "task";
char newStr[10] = "list";
//strncpy(str + 4, newStr, 4);
myStrNCpy(str + 4, newStr, 4);
system(str); system("pause");
}
///04.strpbrk.c
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h> //01.strpbrk();(在串中查找给定字符集中的(首个)字符)
//
// 在pDest这个字符集其中查找另外一个字符集pSrc其中首个
// 出现的字符
char * myStrPBrk(char * pDest, char * pSrc)
{
if (NULL == pDest || NULL == pSrc)
{
return NULL;
}
while ('\0' != *pSrc)
{
char * pTemp = pDest;
while ('\0' != *pTemp)
{
if (*pSrc == *pTemp)
{
return pTemp;
}
++pTemp;
}
++pSrc;
}
return NULL;
} int main04(void)
{
char str1[10] = "abcdefg";
char str2[10] = "123g";
//char * pRes = strpbrk(str1, str2);
char * pRes = myStrPBrk(str1, str2);
printf("%s, %c \n", pRes, *pRes); system("pause");
}
///05.strrchr.c
#include <stdio.h>
#include <stdlib.h>
#include <string.h> //01.strrchr();(字符串其中逆序查找给定字符)
// 格式:char * strrchr(char * pStr, char chr);
// 原理:逆序遍历字符串其中的每一个字符进行对照
char * myStrRChr(char * pStr, char chr)
{
if (NULL == pStr)
{
return NULL;
}
for (char * p = pStr + strlen(pStr) - 1; p >= pStr; --p)
{
if (chr == *p)
{
return p;
}
}
return NULL;
} int main05(void)
{
char str[100] = "calc123";
char * p1 = strrchr(str, 'c');
char * p2 = myStrRChr(str, 'c');
printf("p1:%s, p2:%s \n", p1, p2); system("pause");
}
///06.strrev.c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <locale.h> void setChr0(wchar_t * pWStr)
{
wchar_t *pTemp = pWStr;
while (L'\0' != *pTemp)
{
if (L' ' == *pTemp)
{
*pTemp = L'\0';
}
++pTemp;
}
} void setChrSpace(wchar_t * pWStr)
{
for (int i = 0; i < 7; ++i)
{
if (L'\0' == *(pWStr + i))
{
*(pWStr + i) = L' ';
}
}
} wchar_t * myWcsRevByIndex(wchar_t * pWStr)
{
int i = 0;
int j = wcslen(pWStr) - 1;
for (int k = 0; k < wcslen(pWStr) / 2; ++k)
{
wchar_t wChr = *(pWStr + i);
*(pWStr + i) = *(pWStr + j);
*(pWStr + j) = wChr;
++i;
--j;
}
return pWStr;
} wchar_t * myWcsRevByPoint(wchar_t * pWStr)
{
wchar_t * pHead = pWStr;
wchar_t * pTail = pWStr + wcslen(pWStr) - 1;
while (pHead < pTail)
{
wchar_t wChr = *pHead;
*pHead = *pTail;
*pTail = wChr;
++pHead;
--pTail;
}
return pWStr;
} //01.wcsrev();(宽字符串逆置算法)
// 格式:wchar_t * wcsrev(wchar_t * pWStr);
// 原理:索引夹逼法和指针夹逼法
int main06(void)
{
//char str[10] = "123456";
//_strrev(str);
//printf("%s \n", str); setlocale(LC_ALL, "zh-CN");
wchar_t wstr[10] = L"海华 爱 王芳";
setChr0(wstr);//字符'\0'标识分割位
myWcsRevByIndex(wstr);
myWcsRevByPoint(wstr + 5);
setChrSpace(wstr);
myWcsRevByPoint(wstr);
wprintf(L"%ls", wstr); system("pause");
}
///07.strspn.c
#include <stdio.h>
#include <stdlib.h>
#include <string.h> //01.strspn();(在指定字符串中查找源字符串其中開始部分出现的子集同样字符个数)
// 格式:char * strspn(char * pStr, char * pSrc);
// 原理:逐个遍历目标字符串,然后挨个挨个和源字符串进行比对,直到比对
// 子集其中到第一个不一样的字符为止
// 要求:连续字符串必须是子集,假设不是子集,直接返回0,假设是子集
// 就返回子集其中的字符总个数(包括反复情况)
int main01(void)
{
char str[30] = "1zf1141fang011";
char subStr[100] = "zf10zzzzzfang fang love read book";
int num = strspn(str, subStr);
printf("%d \n", num); system("pause");
}

程序片段(08):字符串.c

内容概要:字符串大写和小写

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h> //01.strlwr();(字符串本体大写转小写)
void myStrLwr(char * pStr)
{
if ('\0' == *pStr)
return;
if ('A' <= *pStr && *pStr <= 'Z')
*pStr += 32;
myStrLwr(++pStr);
} //02.strupr();(字符串本体大写转小写)
void myStrUpr(char * pStr)
{
if ('\0' == *pStr)
return;
if ('a' <= *pStr && *pStr <= 'z')
*pStr -= 32;
myStrUpr(++pStr);
} int main01(void)
{
char str[100] = "asdFGH";
//_strlwr(str);
//myStrLwr(str);
//_strupr(str);
myStrUpr(str);
printf("%s \n", str); system("pause");
}

程序片段(09):error.c

内容概要:stderror

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>//字符串异常函数所在文件
#include <errno.h>//异常宏所在头文件
//#include <errors.h>//异常最经常使用头文件 //01.C语言异常使用特点:
// 1.异常宏定义文件:
// errno.h+errors.h
// 2.异常捕捉函数头文件:
// string.h-->strerror(errno);
// 3.异常状态中断状态:
// abort();
//注:异常宏定义头文件两者仅仅能使用其一,不能同一时候出现
// 其中errors.h文件比較通用一些 int main01(void)
{
FILE * pf = fopen("C:\\1.txt", "r");
char * buffer = strerror(errno);
if (NULL == pf)
{
printf("Error:%s \n", buffer);
abort();//异常-->中断运行状态
} system("pause");
}

程序片段(10):转换.c

内容概要:strtodstrtol

#include <stdio.h>
#include <stdlib.h> //01.strtod();(字符串连续小数提取)
// 格式:double strtod(const char * pStr, char ** ppEndStr);
// 原理:从指定字符串的起始位置開始,遇到非数字或者非小数点就结束数值提取
// 而且将第一个非数字或者非小数点的字符指针提取
//02.strtol();(字符串连续整数提取)
// 格式:long strtol(const char * pStr, char ** radix);
// 原理:从指定字符串的起始位置開始,依照指定进制,遇到非数字就结束数值提取
// 而且将第一个非数字出现的字符指针提取
int main01(void)
{
char str[100] = "刘海华有10个妹子";
char * p = NULL;
double db = strtod(str + 8, &p);
printf("%f, %p, %s \n", db, p, p); system("pause");
}

程序片段(11):字符串.c

内容概要:字符串转换高级

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h> void main01()
{
double data = -12345.4567; int decimal;//整数的位数
int sign;//1代表负,0代表证
int precision = 4;//数字的宽度,强行指定
char *buffer;//指针 buffer = _ecvt(data, precision, &decimal, &sign);//自己主动分配内存
printf("buffer=%s\n", buffer);
printf("sign=%d\n", sign);
printf("decimal=%d\n", decimal);
printf("precision =%d\n", precision); system("pause");
} void main02()
{
double data = -12345.4567; int decimal;//整数的位数
int sign;//1代表负,0代表证
int precision = 14;//数字的宽度大于实际宽端填充,小于,不强行指定,依照实际宽度
char *buffer;//指针 buffer=_fcvt(data, precision, &decimal, &sign);
printf("buffer=%s\n", buffer);
printf("sign=%d\n", sign);
printf("decimal=%d\n", decimal);
printf("precision =%d\n", precision); system("pause");
} void main03()
{
char buffer[128];
//char *buffer=NULL;
double value = 12.2345678;
_gcvt(value, 5, buffer);//5有效数字
printf("%s", buffer); system("pause");
} void main04()
{
unsigned int num = 32;
char str[32] = { 0 };
_ultoa(num, str, 2);
printf("%s\n", str); _ultoa(num, str, 8);
printf("%s\n", str);
_ultoa(num, str, 10);
printf("%s\n", str);
_ultoa(num, str, 16);
printf("%s\n", str); system("pause");
} void main05()
{
int num = -32;
char str[32] = { 0 };
_ltoa(num, str, 2);
printf("%s\n", str); _ltoa(num, str, 8);
printf("%s\n", str);
_ltoa(num, str, 10);
printf("%s\n", str);
_ltoa(num, str, 16);
printf("%s\n", str); system("pause");
}

程序片段(12):字符串插入

内容概要:字符串插入

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <malloc.h> //01.strcat();(字符串末尾追加)
// 格式:char * strcat(char * pDest, char * pSrc);
// 原理:遍历目标字符串,直到字符串结尾标识符'\0'为止
// 然后从这个位置開始进行拷贝有效字符(包括字符串结束标识符'\0')
int main01(void)
{
char str[100] = "wangfang love money ";
char addStr[10] = "hai hua";
strcat(str, addStr);
printf("%s \n", str); system("pause");
} //02.目标字符串长度理想,中间插入指定字符串
// 原理:找到待插入的位置,然后将该位置(包括)之后的全部字符进行后移
// 指定字符串的长度,最后再进行指定字符串的插入操作
int main02(void)
{
char str[100] = "wangfang love money";
char insertStr[30] = "hai hua than ";
char * pPos = strstr(str, "love");
if (NULL != pPos)
{
char *insertPos = pPos + strlen("love") + 1;
int insertLen = strlen(insertStr);
for (char * p = str + strlen(str); p >= insertPos; --p)
{
*(p + insertLen) = *p;
}
for (char * p = insertStr; '\0' != *p; ++p)
{
*insertPos++ = *p;
}
}
printf("%s \n", str); system("pause");
} //02.目标字符串栈内存不足,须要手动扩充栈内存
// 原理:先确定栈内存所需情况,再进行下一步操作
int main03(void)
{
char * pStr = (char *)alloca(20);
strcpy(pStr, "wangfang love money");
printf("%s \n", pStr); char insertStr[30] = "hai hua than ";
int insertLen = strlen(insertStr);
pStr = (char *)alloca(strlen(pStr) + insertLen + 1);
strcpy(pStr, "wangfang love money");
printf("%s \n", pStr); char * pPos = strstr(pStr, "love");
if (NULL != pPos)
{
char * pInsertPos = pPos + strlen("love") + 1;
int insertLen = strlen(insertStr);
for (char * p = pStr + strlen(pStr); p >= pInsertPos; --p)
{
*(p + insertLen) = *p;
}
for (char * p = insertStr; '\0' != *p; ++p)
{
*(pInsertPos++) = *p;
}
}
printf("%s \n", pStr); system("pause");
} //03.基于堆内存的字符串插入
int main04(void)
{
char * pStr = (char *)malloc(20);
strcpy(pStr, "wangfang love money"); char insertStr[30] = "hai hua than ";
int strLen = strlen(pStr);
int insertLen = strlen(insertStr);
pStr = (char *)realloc(pStr, strLen + insertLen + 1);
char * pPos = strstr(pStr, "love");
if (NULL != pPos)
{
char * pStrEnd = pStr + strlen(pStr);
char * pInsertPos = pPos + strlen("love") + 1;
int insertLen = strlen(insertStr);
for (char * p = pStrEnd; p >= pInsertPos; --p)
{
*(p + insertLen) = *p;
}
for (char * p = insertStr; '\0' != *p; ++p)
{
*pInsertPos++ = *p;
}
}
printf("%s \n", pStr); system("pause");
}

程序片段(13):五种循环.c

内容概要:算法与递归

#include <stdio.h>
#include <stdlib.h> int main01(void)
{
for (int i = 0; i < 5; ++i)
{
system("calc");
} system("pause");
} int main02(void)
{
int i = 0;
while (i < 5)
{
system("calc");
++i;
} system("pause");
} int main03(void)
{
int i = 0;
if (i < 5)
{
do
{
system("calc");
++i;
} while (i < 5);
} system("pause");
} int main04(void)
{
int i = 0;
loop:if (i < 5)
{
system("calc");
++i;
}goto loop; system("pause");
} //01.三种结构的实现原理:
// 1.goto语句:统统都能够进行实现
// 2.顺序+分支+循环
int main05(void)
{
infiniteLoop:
system("pause");
goto infiniteLoop; system("pause");
} void go()
{
//system("calc");
printf("1");
go();
} //02.递归大总结:递归函数特点
// 返回值:是否有逆向參数传递
// 參数表:是否有顺序參数传递
// 跳转点:递归函数的调用点
void openCalc(int n)
{
if (0 == n)
return;
system("calc");
openCalc(n - 1);
} int main06(void)
{
openCalc(5); system("pause");
}

程序片段(14):调戏马云.c

内容概要:递归的一些常见应用

#include <stdio.h>
#include <stdlib.h>
#include <Windows.h> void leftToRight(HWND win, int abscissa)
{
if (0 == abscissa)
return;
SetWindowPos(win, NULL, 1366 - abscissa, 0, 200, 300, 1);
leftToRight(win, abscissa - 1);
} void upToDown(HWND win, int ordinate)
{
if (0 == ordinate)
return;
SetWindowPos(win, NULL, 683, 768 - ordinate, 200, 200, 1);
upToDown(win, ordinate - 1);
} int main01(void)
{
HWND win = FindWindowA("StandardFrame", "阿里旺旺");
if (NULL == win)
{
printf("小码哥玩儿失踪! \n");
}
else
{
//for (int i = 0; i < 1024; ++i)
//{
// SetWindowPos(win, NULL, i, i * 768 / 1366, 200, 200, 1);
//}
leftToRight(win, 1366);
upToDown(win, 768);
} system("pause");
}

程序片段(15):01.递归.c+02.腾讯面试题.c

内容概要:递归算法

///01.递归.c
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h> void go1()
{
go1();
} void go2(int n)
{
if (0 == n)
return;
system("calc");
go2(n - 1);
} //01.求解前N项和:
// 1.递归到达终点之后:
// 求解前N项和的计算表达式形成
// 2.计算表达式拆解过程:
// 从最后一项開始进行拆分
// 3.表达式的计算顺序:
// 同一时刻,计算表达式仅仅会运行一段儿
// 4.全部递归函数都仅仅会被调用一次
// 5.递归函数总体返回的结果:
// 是整个计算表达式完结之后的结果
// 6.递归函数的拆解过程是逆序的
// 递归函数会进行逆向拆解
// 7.递归函数的传參注意事项:
// 顺序传參+逆序传參
// 8.递归函数的随时运行情况都是
// 位于运行时堆栈的递归函数
// 9.严格区分运行时堆栈和非运行堆栈
// 10.提前压栈的递归函数状态被保留于
// 非运行时堆栈
// 11.各层次堆栈之间的变量无法跨函数
// 訪问
// 12.递归状态随时驻留
//02.递归函数拆解过程:
// S(n)=n+S(n-1);
// S(n)=n+(n-1)+S(n-2);
// S(n)=n+(n-1)+(n-2)+S(n-3);
// ......
int nItemAdd(int n)
{
if (1 == n)
return 1;
return n + nItemAdd(n - 1);
} int main01(void)
{
int sum = nItemAdd(5);
printf("%d \n", sum); system("pause");
} //03.进制转换:
// 10%2=5...0
// 5 %2=2...1
// 2 %2=1...0
// 1 %2=0...1
// 0 %2=0...0
void decToBin(int dec)
{
int modulus = dec / 2;
int remainder = dec % 2;
if (0 == modulus)
{
putchar(remainder + '0');
return;
}
decToBin(modulus);
putchar(remainder + '0');
} int main02(void)
{
int decNum = 0;
scanf("%d", &decNum);
printf("待转换的十进制整数是:%d \n", decNum);
decToBin(decNum); system("pause");
}
///02.腾讯面试题.c
#include <stdio.h>
#include <stdlib.h> //01.步法一次能够一步,也能够两步,走
// 50阶台阶有多少中走法?
// 1-->1(1)
// 2-->11+2(2)
// 3-->111+12+21(3)
// 4-->1111+112+121+211+22(5)
// S(n)=S(n-1)+S(n-2);
//02.递归函数的调用次数分析:
// countMethod(stepNum - 1):仅仅会运行一次
// countMethod(stepNum - 2):都会运行两次
int countMethod(int stepNum)
{
if (1 == stepNum)
{
return 1;
}
else if (2 == stepNum)
{
return 2;
}
return countMethod(stepNum - 1) + countMethod(stepNum - 2);
} int main03(void)
{
printf("%d \n", countMethod(5)); system("pause");
}

程序片段(16):stack.h+stack.c+栈实现.c

内容概要:栈实现递归

///stack.h
#pragma once//在同一个代码文件其中,标识当前头文件仅仅会被包括一次 #define EN 100 typedef struct
{
int top;
int data[EN];
} Stack; void initStack(Stack * pStack);
int isEmpty(Stack * pStack);
int isFull(Stack * pStack);
int getTop(Stack * pStack);
void pushStack(Stack * pStack, int value);
void popStack(Stack * pStack);
///stack.c
#include "stack.h"
#include <memory.h> void initStack(Stack * pStack)
{
memset((*pStack).data, 0, EN * sizeof(int));
(*pStack).top = -1;
} int isEmpty(Stack * pStack)
{
if (-1 == (*pStack).top)
return 1;
return 0;
} int isFull(Stack * pStack)
{
if (EN - 1 == (*pStack).top)
return 1;
return 0;
} int getTop(Stack * pStack)
{
return (*pStack).data[(*pStack).top];
} void pushStack(Stack * pStack, int value)
{
if (1 == isFull(pStack))
return;
(*pStack).top += 1;
(*pStack).data[(*pStack).top] = value;
} void popStack(Stack * pStack)
{
if (1 == isEmpty(pStack))
return;
(*pStack).top -= 1;
}
///栈实现.c
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include "stack.h" int main01(void)
{
int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
Stack stack;
initStack(&stack);
for (int i = 0; i < 10; ++i)
{
pushStack(&stack, *(arr + i));
printf("%d \n", getTop(&stack));
popStack(&stack);
} system("pause");
} int main02(void)
{
int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
Stack stack;
initStack(&stack);
for (int i = 0; i < 10; ++i)
{
pushStack(&stack, *(arr + i));
}
while (!isEmpty(&stack))
{
printf("%d \n", getTop(&stack));
popStack(&stack);
} system("pause");
} //01.十进制整数转二进制整数:
// 10%2=5...0
// 5 %2=2...1
// 2 %2=1...0
// 1 %2=0...1
void decToBin(int dec)
{
int modulus = dec / 2;
int remainder = dec % 2;
if (0 == modulus)
{
putchar(remainder + '0');
return;
}
decToBin(modulus);
putchar(remainder + '0');
} int main03(void)
{
int decNum = 0;
scanf("%d", &decNum);
printf("decNum = %d \n", decNum);
decToBin(decNum); system("pause");
} int main04(void)
{
int decNum = 0;
scanf("%d", &decNum);
printf("待转换的十进制整数为:%d \n", decNum); Stack stack;
initStack(&stack);
//while (decNum)
//{//顺序压栈
// pushStack(&stack, decNum % 2);
// decNum /= 2;
//}
//while (!isEmpty(&stack))
//{//逆序弹栈
// printf("%d", getTop(&stack));
// popStack(&stack);
//}
while (decNum)
{//压栈弹栈
pushStack(&stack, decNum % 2);
printf("%d", getTop(&stack));
popStack(&stack);
decNum /= 2;
} system("pause");
}

程序片段(17):字符串常量表达式计算终极版.c

内容概要:编译原理-第一课表达式计算器

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h> void removeBlankSpace(char * pStr)
{
char * p1 = pStr;
char * p2 = pStr;
while (*p1 = *p2++)
{
if (' ' != *p1)
{
++p1;
}
}
} int isNumber(char chr)
{
if ('0' <= chr && '9' >= chr)
return 1;
return 0;
} char * parentheses(char * pStr, int * pIndex)
{
char * pResultStr = NULL;
int parenNum = 0;
int resultStrLeftIndex = *pIndex;
do
{
switch (*(pStr + *pIndex))
{
case '(':
++parenNum;
break;
case ')':
if (0 == parenNum)
{
pResultStr = (char *)calloc(++*pIndex - resultStrLeftIndex, sizeof(char));
strncpy(pResultStr, pStr + resultStrLeftIndex, *pIndex - resultStrLeftIndex - 1);
printf("(%s) \n", pResultStr);
return pResultStr;
}
else
{
--parenNum;
}
}
} while (pStr + (*pIndex)++);
} double getValue(char * pStr, int * pIndex)
{
int dbInt = 0;
double dbDouble = 0.0;
int index = *pIndex;
while ('(' == *(pStr + index))
{
*pIndex = ++index;
char * pTmpStr = parentheses(pStr, pIndex);
double caculateAddSub(char *);
double dbValue = caculateAddSub(pTmpStr);
free(pTmpStr);
pTmpStr = NULL;
return dbValue;
}
while (isNumber(*(pStr + index)))
{
dbInt = dbInt * 10 + (*(pStr + index++) - '0');
}
if ('.' == *(pStr + index))
{
double dbMutiple = 1.0;
while (isNumber(*(pStr + ++index)))
{
dbDouble += (*(pStr + index) - '0') * (dbMutiple /= 10);
}
}
*pIndex = index;
return dbInt + dbDouble;
} double caculateMulDiv(char * pStr, int * pIndex)
{
double result = getValue(pStr, pIndex);
for (;;)
{
if ('*' == *(pStr + *pIndex))
{
++*pIndex;
result *= getValue(pStr, pIndex);
}
else if ('/' == *(pStr + *pIndex))
{
++*pIndex;
result /= getValue(pStr, pIndex);
}
else
{
break;
}
}
return result;
} double caculateAddSub(char * pStr)
{
int index = 0;
double result = caculateMulDiv(pStr, &index);
while (1)
{
switch (*(pStr + index++))
{
case '\0':
return result;
case '+':
result += caculateMulDiv(pStr, &index);
break;
case '-':
result -= caculateMulDiv(pStr, &index);
break;
default:
break;
}
}
return result;
} int main05(void)
{
char constExpress[1024] = { 0 };
printf("请输入待处理的常量表达式:");
scanf("%[^\n]", constExpress);
removeBlankSpace(constExpress);
printf("经过预处理的常量表达式为:%s \n", constExpress);
printf("常量表达式的终于计算结果为:%lf \n", caculateAddSub(constExpress)); system("pause");
}

20160218.CCPP体系具体解释(0028天)的更多相关文章

  1. 20160218.CCPP体系详解(0028天)

    程序片段(01):加法.c 内容概要:字符串计算表达式 #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <st ...

  2. 20160208.CCPP体系具体解释(0018天)

    程序片段(01):main.c 内容概要:PointWithOutInit #include <stdio.h> #include <stdlib.h> //01.野指针具体解 ...

  3. 20160205.CCPP体系具体解释(0015天)

    程序片段(01):01.杨辉三角.c 内容概要:杨辉三角 #include <stdio.h> #include <stdlib.h> #define N 10 //01.杨辉 ...

  4. 20160227.CCPP体系具体解释(0037天)

    程序片段(01):01.一对一模式.c+02.中介者模式.c+03.广播模式.c 内容概要:事件 ///01.一对一模式.c #include <stdio.h> #include < ...

  5. 20160206.CCPP体系具体解释(0016天)

    代码片段(01):.指针.c+02.间接赋值.c 内容概要:内存 ///01.指针 #include <stdio.h> #include <stdlib.h> //01.取地 ...

  6. 20160210.CCPP体系具体解释(0020天)

    程序片段(01):01.二级指针.c 内容概要:二级指针 #include <stdio.h> #include <stdlib.h> //01.二级指针: // 1.使用场景 ...

  7. 20160216.CCPP体系具体解释(0026天)

    程序片段(01):01.MemCpy.c 内容概要:内存拷贝 #include <stdio.h> #include <stdlib.h> #include <memor ...

  8. 20160222.CCPP体系具体解释(0032天)

    程序片段(01):宽字符.c+字符串与内存四区.c 内容概要:宽窄字符 ///宽字符.c #include <stdio.h> #include <stdlib.h> #inc ...

  9. 20160225.CCPP体系具体解释(0035天)

    程序片段(01):CircleList.h+CircleList.c+main.c 内容概要:环形链表 ///CircleList.h #pragma once #include <stdio. ...

随机推荐

  1. .Net商品管理(注释,百度,提问,对比,总结)

    管理控制器 using System; using System.Collections.Generic; using System.Linq; using System.Web; using Sys ...

  2. Integer 和 int的种种比较

    public static void main(String[] args) { int i = 128; Integer i2 = 128; Integer i3 = new Integer(128 ...

  3. 快速定位java系统的线上问题--转

    原文地址:http://m.blog.csdn.net/article/details?id=43376943 前言:我们的场景并没有像BAT等大型互联网公司里的系统那么复杂,但是基本上也有一定的规模 ...

  4. P1328 生活大爆炸版石头剪刀布

    题目描述 石头剪刀布是常见的猜拳游戏:石头胜剪刀,剪刀胜布,布胜石头.如果两个人出拳一样,则不分胜负.在<生活大爆炸>第二季第8 集中出现了一种石头剪刀布的升级版游戏. 升级版游戏在传统的 ...

  5. 基于Linux下Iptables限制BT下载的研究

    基于Linux下Iptables限制BT下载的研究   摘要:     当前BT下载技术和软件飞速发展,给人们网上冲浪获取资源带来了极大的便利, 但同时BT占用大量的网络带宽等资源也给网络和网络管理员 ...

  6. $_FILES参数详解及简单<form>表单无刷新上传文件

    $_FILES:经由 HTTP POST 文件上传而提交至脚本的变量,类似于旧数组$HTTP_POST_FILES 数组(依然有效,但反对使用)详细信息可参阅 POST方法上传 $_FILES数组内容 ...

  7. DEDE 修改后台图集上传单个图片的大小限制

    默认情况下,DEDE图集中单个图片大小限制在2M以内,而有时我们需要上传一个2M以上的文件,这是只要修改几个文件就可以实现了. 一.需要修改php.ini这个文件,我们必须保证PHP的配置中允许上传一 ...

  8. 【Codeforces Round #459 (Div. 2) D】MADMAX

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] f[x][y][z][2] 表示第一个人到了点x,第二个人到了点y,当前轮的字母(1..26),当前轮到谁走的情况下,谁赢. 写个记 ...

  9. js正則表達式--验证表单

    检測手机号码:/0? (13|14|15|18)[0-9]{9}/ 检測username:(数字,英文,汉字.下划线.中横线):/^[A-Za-z0-9_\-\u4e00-\u9fa5]+$/ pas ...

  10. Timus 1935. Tears of Drowned 具体解释

    Old Captain Jack Sparrow's friend Tia Dalma, the fortuneteller and prophetess, often makes potions. ...