20160130.CCPP体系详解(0009天)
程序片段(01):hanoi.c+汉诺塔.c
内容概要:汉诺塔
///hanoi.c
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
int main01(void)
{
//int a[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 0 };//一维数组,代码块儿初始化方式(指定)
//for (int i = 0; i < 10; i++)
//{
// printf("%5d", a[i]);//数组的索引都是从0开始的
//}
int a[10][3] = { 0 };//二维数组,代码块儿初始化方式(统一)
for (int i = 0; i < 10; i++)
{//行
for (int j = 0; j < 3; j++)
{//列
printf("%5d", a[i][j]);
}
printf("\n");
}
system("pause");
}
int main02(void)
{
int n = 0;
int a[10][3] = { 0 };//二维数组,代码块儿初始化方式(统一)
scanf("%d", &n);
for (int i = 0; i < n; i++)//控制
{//-1的原因是因为,索引最大为9,索引最大,赋值却最小-->索引逆向赋值i=0-->index=10-1-i-->sequence=10-0
a[10 - 1 - i][0] = n - i;//布局
}
for (int i = 0; i < 10; i++)//控制行
{
for (int j = 0; j < 3; j++)//控制列
{
printf("%5d", a[i][j]);
}
printf("\n");
}
system("pause");
}
///汉诺塔.c
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
int hanoiTower[10][3] = { 0 };//二维数组,代码块儿初始化(统一形式)
//01.将二维数组的操作采用图形化方式模拟出来:
// 1.设计操作流程:
// 汉诺塔逻辑实现-->显示汉诺塔流程-->补充函数说明
// 2.所涉及到的设计模式:
// MVC设计模式(简化版本)
//汉诺塔辅助程序
void movehanoiTower(char x, char y);//移动汉诺塔的过程当中,保留移动痕迹到二维数组(逻辑&数据-->链接起来)
//汉诺塔逻辑实现
void hanoiTowerLogic(unsigned int n, char i, char j, char k);//汉诺塔主逻辑
//显示汉诺塔流程
void showHanoiTower(int hanoiTower[10][3]);//显示汉诺塔数据
void moveHanoiTower(char x, char y)
{
//实质:就是数组当中两个位置的字符数据之间的交换
//hanoiTower[imove][m]<--->hanoiTower[jmove][n];
int m = x - 65;//字符形式转换为整数相差形式(间接记忆字符)
int n = y - 65;
int imove = -1;
int jmove = -1;
for (int i = 0; i < 10; i++)
{
if (0 != hanoiTower[i][m])
{//检索第一个不为0的
imove = i;
break;
}
}
if (0 == hanoiTower[9][n])
{
jmove = 9;
}
else
{
jmove = 10;
for (int i = 0; i < 10; i++)
{
if (0 != hanoiTower[i][n])
{
jmove = i;
break;
}
}
jmove -= 1;
}
//将用于间接记忆字符的整数形式进行交换
int temp = hanoiTower[imove][m];
hanoiTower[imove][m] = hanoiTower[jmove][n];
hanoiTower[jmove][m] = temp;
}
void hanoiTowerLogic(unsigned int n, char i, char j, char k)
{
if (0 == n)
return;
else if (1 == n)
{
//printf("%c-->%c \n", i, k);
moveHanoiTower(i, k);
showHanoiTower(hanoiTower);
return;
}
hanoiTowerLogic(n - 1, i, k, j);
//printf("%c-->%c \n", i, k);
moveHanoiTower(i, k);
showHanoiTower(hanoiTower);
hanoiTowerLogic(n - 1, j, i, k);
}
void showHanoiTower(int hanoiTower[10][3])
{
printf("%5c%5c%5c \n", 'A', 'B', 'C');
printf("---------------\n");
for (int i = 0; i < 10; i++)
{
for (int j = 0; j < 3; j++)
{
printf("%5d", hanoiTower[i][j]);
}
printf("\n");
}
}
int main(void)
{
int n = 0;
scanf("%d", &n);
for (int i = 0; i < n; i++)//控制
{
hanoiTower[n - 1 - i][0] = n - i;//布局
}
hanoiTowerLogic(n, 'A', 'B', 'C');
showHanoiTower(hanoiTower);
system("pause");
}
程序片段(02):QQ.c
内容概要:调戏妹子上QQ
#include <stdio.h>
#include <stdlib.h>
#include <Windows.h>
#include <time.h>
int main01(void)
{
//HWND win = FindWindowA("TXGuiFoundation", "QQ");
HWND win = FindWindowA("StandardFrame", "阿里旺旺");
int i = 0;
POINT point;
point.x = point.y = 0;
time_t te;
unsigned int seed = (unsigned int)time(&te);
srand(seed);
int rnum = 0;
while (1)
{
GetCursorPos(&point);
rnum = rand() % 4;
switch (rnum)
{
case 0:
SetWindowPos(win, NULL, point.x - 500, point.y - 500, 0, 0, 1);//1:禁止修改窗体尺寸
break;
case 1:
SetWindowPos(win, NULL, point.x + 500, point.y - 500, 0, 0, 1);
break;
case 2:
SetWindowPos(win, NULL, point.x - 500, point.y + 500, 0, 0, 1);
break;
case 3:
SetWindowPos(win, NULL, point.x + 500, point.y + 500, 0, 0, 1);
break;
}
Sleep(1000);
++i;
if (1000 == i)
//break;//跳出
return;//结束
}
system("taskkill /f /im iexplore.exe");
MessageBoxB(0, "发现病毒", "提示信息", 0);
system("pause");
}
程序片段(03):模块.c
内容概要:鬼哭神嚎
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <Windows.h>
#include <time.h>
#include <process.h>//多线程
//01.如何将一个控制台应用程序转换成为Windows应用程序:
// 控制台-->Windows:实质就是去掉黑窗口
// 控制台应用程序-->链接为-->Windows应用程序(可有Windows窗口,也可以没有)
#pragma comment (linker, "/subsystem:\"windows\" /entry:\"mainCRTStartup\"")
void setDktopBkgroundPicture(char *path)
{
SystemParametersInfoA(20, 0, path, 3);
}
void setBkgroundMusic(char *path)
{
ShellExecuteA(0, "open", path, 0, 0, 0);//0:代表隐藏(最后一个)
}
void setFegroundText(int x, int y, char * text)
{
HWND win = GetDesktopWindow();//获取系统窗体(当前程序运行时所显示的整个窗体)
HDC dc = GetWindowDC(win);//获取设备的上下文(以待用于进行设置)
SetTextColor(dc, RGB(255, 0, 0));
SetBkColor(dc, RGB(0, 0, 255));
while (1)
{
TextOutA(dc, 300, 400, text, strlen(text));//显示文本
Sleep(2000);
}
}
void bgJpgPicture(void *p)
{
int rnum = 0;
char *path[200] = { 0 };
time_t te;
unsigned int seed = (unsigned int)time(&te);
srand(seed);
while (1)
{
rnum = rand() % 9;
sprintf(path, "C:\\Users\\ZHEN\\Desktop\\TestPictore\\%d.jpg", rnum);
setDktopBkgroundPicture(path);
Sleep(1000);
}
}
void bgMp3Music(void *p)
{
int rnum = 0;
char *path[200] = { 0 };
time_t te;
unsigned int rseed = (unsigned int)time(&te);
srand(rseed);
while (1)
{
system("taskkill /f /im mediaplayer.exe");
rnum = rand() % 4;
sprintf(path, "C:\\Users\\ZHEN\\Desktop\\TestMp3\\%d.mpe", rnum);
setBkgroundMusic(path);
Sleep(10000);
}
}
void feFontText(void *p)
{
setFegroundText(50, 50, "i love you!!!");
}
int main01(void)
{
setDktopBkgroundPicture("C:\\Users\\ZHEN\\Desktop\\TestPicture\\3.jpg");
setBkgroundMusic("C:\\Users\\ZHEN\\Desktop\\TestMusic\\3.mp3");
setFegroundText(30, 40, "测试文本");
//02.开启多线程执行某一段儿线程任务代码:
// _beginthread(arg1, arg2, arg3);
// arg1:线程任务代码
// arg2:栈内存尺寸
// arg3:线程任务参数
_beginthread(bgJpgPicture, 0, NULL);
_beginthread(bgMp3Music, 0, NULL);
_beginthread(feFontText, 0, NULL);
system("pause");
}
程序片段(04):位运算.c
内容概要:打印整数原码补码反码
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
//01.位运算使用注意事项:
// 1.位运算只是适用于整数的,不适用于实数
// 2.由于两者的存储方式不一样:
// 整数采取的是补码进行存储
// 实数采取的是阶码进行存储
//02.如何不断的获取一个整数的二进制形式的最高位?
// 举例:原理图
// 10101010010100
// & 10000000000000
// ----------------------
// 10000000000000
// 步骤:执行体
// 0.不断的判断是否将整数的32位全部移完
// 1.不断的将整数进行左移位(<<)运算
// 2.不断的用1进行按位与(&)运算
//03.如何确定两个二进制位进行加法运算之后的对应的二进制位数是多少?
// 举例:原理图
// 00 0 0^0-->0
// 01 1 0^1-->1
// 10 1 1^0-->1
// 11 0 1^1-->0
// 异或运算符特性
// 可以模拟两个二进制位加法运算之后,所对应的具体二进制位是多少.
//04.正负整数的原码反码补码使用规律:
// 1.内存当中所有的整数都是按照补码进行存储的!
// 所以打印所有整数的补码就等同于直接打印整数的内存存储形式
// 2.正整数的原码反码和补码相同(就是直接的内存存储形式)
// 3.负整数的原码反码和补码不相同:
// 补码:就是直接的内存存储形式,可以进行直接打印
// 反码:就是补码-1
// 原码:补码-->对补码(求反,再+1)-->得到原码(符号位丢失,需要补充符号位)
int main01(void)
{//正整数的原码
int inum = 0;
int num1L31 = 1 << 31;
scanf("%d", &inum);
for (int i = 1; i <= 32; i++)
{
if (inum & num1L31)
putchar('1');
else
putchar('0');
if (0 == i % 4)
printf(" ");
inum <<= 1;
}
system("pause");
}
int main02(void)
{//正负整数的原码
int inum = 0;
int num1L31 = 1 << 31;
scanf("%d", &inum);
if (inum < 0)
{
//0000 0000 0000 0110 +6:原码
//1000 0000 0000 0110 -6:原码
//1111 1111 1111 1001 -6:反码(取反)
//1111 1111 1111 1010 -6:补码(加一)
//0000 0000 0000 0101 -6:补码(再取反)
//0000 0000 0000 0110 -6:补码(再加一)
//1000 0000 0000 0110 -6:补码(补符号)
inum = ~inum + 1;//负数的原码(符号位丢失)
inum = inum | num1L31;//补充符号位
}
for (int i = 1; i <= 32; i++)
{
if (inum & num1L31)
putchar('1');
else
putchar('0');
if (i % 4 == 0)
printf(" ");
inum <<= 1;
}
system("pause");
}
int main03(void)
{//正负整数的反码
int inum = 0;
int num1L31 = 1 << 31;
scanf("%d", &inum);
if (inum < 0)
{
inum = inum - 1;//负整数的反码
}
for (int i = 1; i <= 32; i++)
{
if (inum & num1L31)
putchar('1');
else
putchar('0');
if (0 == i % 4)
printf(" ");
inum <<= 1;
}
system("pause");
}
程序片段(05):补码原码反码.c
内容概要:补码原码反码转换工具
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
//获取整数(正负整数)的补码(机器存储形式)
void binBCode(int inum, char binStr[33])
{
int num1L31 = 1 << 31;
for (int i = 1; i <= 32; i++)
{//1:进来的哪一次就是1-->1~32-->共32个映射对
if (inum & num1L31)
binStr[i - 1] = '1';
else
binStr[i - 1] = '0';
inum <<= 1;
}
}
//获取整数(正负整数)的反码
void binFCode(int inum, char binStr[33])
{
int num1L31 = 1 << 31;
if (inum < 0)
{
--inum;
}
for (int i = 1; i <= 32; i++)
{
if (inum & num1L31)
binStr[i - 1] = '1';
else
binStr[i - 1] = '0';
inum <<= 1;
}
}
//数组的副本(实体数据)拷贝浪费内存,所以数组默认采用传址(地址)
//获取整数(正负整数)的原码
void binYCode(int inum, char binStr[33])
{
int num1L31 = 1 << 31;
if (inum < 0)
{
inum = ~inum + 1;//负整数的原码(丢失符号位)
inum = inum | num1L31;//(补充符号位)
}
for (int i = 1; i <= 32; i++)
{
if (inum & num1L31)
binStr[i - 1] = '1';
else
binStr[i - 1] = '0';
inum <<= 1;
}
}
int main(void)
{
int inum = 0;
char strBinY[33] = { 0 };
char strBinF[33] = { 0 };
char strBinB[33] = { 0 };
scanf("%d", &inum);
binYCode(inum, strBinY);
printf("%s \n", strBinY);
binFCode(inum, strBinF);
printf("%s \n", strBinF);
binBCode(inum, strBinB);
printf("%s \n", strBinB);
system("pause");
}
程序片段(06):进制.c
内容概要:进制转换工具
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
//01.十进制转任意进制的原理:
// 十进制 二进制 八进制 十六进制
// 10 /2=5 %2=0 %8=2 %16=10
// 5 /2=2 %2=1 %8=1 0xA
// 2 /2=1 %2=0 012
// 1 /2=0 %2=1
// 1010
// 原理解析完毕:
//02.二进制转任意进制的原理:
// 十进制:每个位进行运算
// 八进制:将二进制当中的每3个二进制位当中一个8进制位处理
// 十六进:将二进制当中的每4个二进制位当中一个16进制位处理
void decToBin(int inum, char binStr[33], int i)
{
if (0 == inum)
return;
binStr[i] = inum % 2;
decToBin(inum / 2, binStr, ++i);
}
int main(void)
{
char binStr[33] = { 0 };
decToBin(10, binStr, 1);
printf("%s", binStr);
system("pause");
}
//void to2str(int num, int i, char str2[32])
//{
// to2str(num / 2,i+1,str2);//位数向前
// //printf("%d", num % 2);
// str2[i] = (num % 2) + '0';//字符整数的转换
// }
//
//}
//void to8str(int num, int i, char str8[32])
//{
// if (num == 0)
// {
// return;
// }
// else
// {
// to8str(num / 8,i+1,str8);
// str8[i] = (num % 8) + '0';//字符整数的转换
// }
//}
//
//void to16str(int num, int i, char str16[32])
//{
// if (num == 0)
// {
// return;
// }
// else
// {
//
// to16str(num / 16,i+1,str16);
// //printf("%x", num % 16);
// if (num % 16<10)
// {
// str16[i] = (num % 16) + '0';//字符整数的转换
// }
// else
// {
// //10,11,12,13,14,15
// str16[i] = (num % 16) - 10 + 'A';
// }
//
//
// //'A' 10
// }
//
//}
//
//void main()
//{
//
// int num = 0;
// char str2[32] = { 0 };
// char str8[32] = {0};
// char str16[32] = {0};
//
//
// scanf("%d", &num);
//
//
// to2str(num,0,str2);
// _strrev(str2);
// printf("\n%s", str2);
//
//
// to8str(num, 0, str8);
// _strrev(str8);
// printf("\n%s", str8);
//
// to16str(num, 0, str16);
// _strrev(str16);
// printf("\n%s", str16);
//
//
// getchar();
// getchar();
//}
//
//void to2(int num)
//{
// if (num==0)
// {
// return;
// }
// else
// {
//
// to2(num / 2);
// printf("%d", num % 2);
// }
//
//}
//
//void to8(int num)
//{
// if (num == 0)
// {
// return;
// }
// else
// {
//
// to8(num / 8);
// printf("%d", num % 8);
// }
//
//}
//
//void to16(int num)
//{
// if (num == 0)
// {
// return;
// }
// else
// {
/**重点内容**/
// to16(num / 16);
// printf("%x", num % 16);
// }
//
//}
//
//
//void main1()
//{
// int num = 0;
// scanf("%d", &num);
// to2(num);
// printf("\n");
// to8(num);
// printf("\n");
// to16(num);
// getchar();
// getchar();
//}
程序片段(07):add.c
内容概要:时间编程
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
//01.register&volatile关键的使用:
// 1.使用意义不同:
// register:标识寄存器变量
// volatile:标识内存变量,强制读取内存变量
// 特点:register寄存器变量运算较快于volatile内存变量
// 因为其减少了不必要的读取内存时间(读取过程时间)
// 2.编译器的优化特点不同:
// 如果一个内存变量被频繁的进行使用,那么:
// VC编译器:会自动进行优化操作
// GCC编译器:不会进行自动优化操作
// 特点:register对GCC有效,对VC可能无效,VC不听话
// 3.内容总结:
// (1).在程序运行过程当中,根据需要到内存中的相应变量存储
// 单元中进行调用,如果一个变量在程序中频繁使用,例如循环变量
// 那么,系统就必须多次访问该内存中的变量单元,影响程序的执行效率
// 因此,CCPP语言当中还定义了一种变量,不是保存在内存之中的变量
// 而是直接存储于CPU内部的寄存器当中,这种变量被称之为寄存器变量
// (2).寄存器变量的定义形式为:
// register 类型标识符 变量名;
// (3).寄存器与机器硬件密切相关,不同类型的计算机,寄存器的数目是不一样的
// 通常为2到3个,对于在一个函数中说明的多余2到3个的寄存器变量,C编译
// 程序会自动的将寄存器变量变为自动变量
// (4).寄存器说明符只能用于说明函数中的局部变量和函数中的形参变量,因此
// 不允许将全局变量或者静态变量说明为"register"形式.
// VC会自动进行寄存器变量的优化,不可以对寄存器变量进行取内存地址操作
// GCC需要手动指定,MINGW是GCC编译器移植到Windows的版本
// C语言寄存器变量不可以进行取内存地址操作,C++可以,因为C++会
// 在内存当中给C语言寄存器变量保存一个副本
// 4.特殊特点总结:
// 某些情况之下的变量必须强制读内存,因为寄存器变量如果随时都在变化,而多线程
// 情况之下每条线程访问的都是同一个内存变量,如果迟迟不进行读取内存的操作
// 那么,寄存器变量的变量不会被映射到内存变量当中,导致数据变化不能及时生效
int main01(void)
{
time_t start, end;
time(&start);//获取开始时刻的时间
//进行浮点数运算的模拟
volatile double result = 0;
//VC会自动将频繁使用的内存变量优化为寄存器变量
for (volatile double i = 0; i < 100000000; i++)
{
result += i*1.0;
}
time(&end);//获取结束时刻的时间
printf("消耗的时间为:%f \n", difftime(end, start));
}
int main02(void)
{
time_t start, end;
time(&start);
register double result = 0;
for(register double i = 0; i < 100000000; i++)
{
result += i *1.0;
}
time(&end);
printf("消耗时间为:%f \n", difftime(end, start));
}
//02.测试寄存器变量和内存变量的最佳方式:是通过相同阶段的CPU进行测试才能最准确:
// 原理:让一条线程通过一条执行流处理内存变量和寄存器变量-->这样的误差最小
// 免得CPU运算赫兹忽高忽低
int main03(void)
{
main01();
main02();//同样的代码段儿被加载进内存,如果执行相同的操作CPU也会进行优化操作
system("pause");
}
程序片段(08):main.c
内容概要:TestTime
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main01(void)
{
time_t start, end;
time(&start);
volatile double result = 0.0;
volatile int i;//GCC当中的循环变量必须申明在for循环外部
for (i = 0; i < 100000000; i++)
{//没有优化double是内存变量,13s;采取优化double是寄存器变量,3s
result+=i*1.0;
}
time(&end);
printf("消耗时间为:%f \n", difftime(end, start));
}
int main02(void)
{
time_t start, end;
time(&start);
register double result = 0.0;
register int i;
for (i = 1; i < 100000000; i++)
{
result += i*1.0;
}
time(&end);
printf("消耗时间为:%f \n", difftime(end, start));
}
int main(void)
{
main01();
main02();
}
程序片段(09):run.c+test.c
内容概要:dll调用
///run.c
#include <Windows.h>
_declspec(dllexport) void go()
{
MessageBoxA(0, "World", "Hello", 0);
}
_declspec(dllexport) int add(int a, int b)
{
return a + b;
}
///test.c
#include <stdio.h>
#include <stdlib.h>
#include <Windows.h>
//01.如何获取函数指针类型?
// 将函数声明头的函数名称替换为(*函数指针名称)
// 举例:void fp();-->void (*fp)();
// fp的类型就是void (*)();
// void go()---->void (*fp1)();
// int add(int a, int b)---->int (*fp2)(int a, int b);
//02.如何使用动态库?
// 动态库加载LoadLibraryA();
// 动态库函数GetProcAddress();
// 动态库释放FreeLibrary();
int main01(void)
{
HMODULE hmod = LoadLibraryA("01.DLL调用.dll");//动态库加载
if (NULL == hmod)
{
system("echo error load! \n");
}
void(*fp1)() = (void(*)())GetProcAddress(hmod, "go");
int(*fp2)(int a, int b) = (int(*)(int a, int b))GetProcAddress(hmod, "add");
if (NULL == fp1 || NULL == fp2)
{
system("echo error find! \n");
}
else
{
fp1();
printf("%d \n", fp2(10, 20));
}
FreeLibrary(hmod);//动态库释放
system("pause");
}
程序片段(10):add.c
内容概要:计算器
#include <stdio.h>
#include <stdlib.h>
//01.规律说明:
// 100%7=2
// 100求余7之后为2
// 100-(100/7)*7=2
// 100减去整除数*7=2
// 5%3=2
// 73%4=1 73%5=3
// 74%4=2 74%5=4
// 75%4=3 75%5=0
// 73---->0100 1001
// % 4---->0000 0100
//------------------------
// 1 0000 0001
// 74---->0100 1010
// % 4---->0000 0100
//------------------------
// 2 0000 0010
//10-->2
//100-->4
//1000-->8
//10000---16
// 73---->0100 1001
// % 5---->0000 0101
//------------------------
// 3---->0000 0011
int main(void)
{
unsigned int num = 73;//余数
printf("%d \n", num - (num & ~3));
system("pause");
}
////11 0 1
////10 1 0
////01 1 0
////00 0 0
//
////0011 3 15
////0101 5 16
// //21 +10
////0010 进位
//
////0110 ^ 6
//
////1000 8
//
//int add(int a,int b)
//{
// int wei = 0;
// int jinwei = 0;
//
// do
// {
// wei = a^b;//处理位加法
// jinwei = (a&b) << 1;//进位
//
// a = wei;//没有进位的加法
// b = jinwei;//进位
// } while (b!=0);
// return a;
//}
//
//
//int dadd(int a, int b)
//{
// if (b==0)
// {
// return a;
// }
// else
// {
// int wei = a^b;
// int jinwei = (a&b) << 1;
// dadd(wei, jinwei);
// }
//}
//
//
//void main1()
//{
// printf("%d", dadd(113, 15));
// getchar();
//}
程序片段(11):go.c
内容概要:最小公倍数最大公约数
#include <stdio.h>
#include <stdlib.h>
//01.最小公倍数和最大公约数:
// 条件:现有两个整数num1和num2
// 那么:num1*num2=minGB*maxGY;
// 编程:
// 方式一:
// 假设num1<num2
// 最小公倍数:
// 从两个整数当中较大的那个整数开始向大数遍历
// 如果(0==num/num2)&&(0==num/num1)
// 最大公约数:
// 从两个整数当中较小的那个整数开始向小数遍历
// 如果(0==num1/num)&&(0==num2/num)
// 方式二:
// 利用:num1*num2=minGB*maxGY
//02.举例说明特点:
// num1=10;num2=25;
// 10 25 50-->minGB
// 10 25 5--->maxGY
// 原理:辗转相除法
// 10 % 25 = 10; //被除数/除数=余数
// 25 % 10 = 5; //除数/余数
// 10 % 5 = 0; //除数/余数
int maxGY(int i, int j)
{
if (0 == i % j)
return j;//跳出
else
return maxGY(j, i % j);//递归
}
int main01(void)
{
int a = 25;
int b = 110;
printf("%d, %d \n", maxGY(25, 110), 25 * 110 / maxGY(25, 110));
system("pause");
}
程序片段(12):猜数字.c
内容概要:猜数字
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <Windows.h>
#include <time.h>
//01.健壮的应用程序当中经常使用abort提示错误:
// 1.相当于其它语言当中的异常处理机制模拟
// 2.区分编译错误和运行时异常
// 编译错误:代码本身存在语法错误
// 运行时异常:实在编译没有错误的情况之下发生的
int main01(void)
{
int a, b;
scanf("%d%d", &a, &b);
if (b == 0)
{
abort();//提示错误
}
else
{
int c = a / b;
}
system("pause");
}
int main02(void)
{
time_t te;
unsigned int rseed = (unsigned int)time(&te);
srand(rseed);
int rnum = rand() % 100 + 1;//1~100
int gnum = 0;
while (1)
{
scanf("%d", &gnum);
if (rnum > gnum)
puts("小了");
else if (rnum < gnum)
puts("大了");
else
{
puts("小伙子才对了! ");
break;
}
}
//这后面的代码需要放置于多线程当中运行才行
int i = 0;//否则限时功能不会生效
while (1)
{
Sleep(1000);
++i;
if (5 == i)
//abort();//提示错误
//break;//终止循环
exit(0);//结束程序
}
system("pause");
}
程序片段(13):type.cpp
内容概要:typedef
#include <stdio.h>
#include <stdlib.h>
#include <iostream>//CPP输入输入
using namespace std;//使用名称空间
//01.给任意类型取别名的方式:typedef使用
// 规律:在声明变量的基础之上前置typedef关键字
// 为已经存在的类型另起一个别名(原名和别名都有进行使用)
// 只不过typedef具有简化类型名称的作用,而且某些地方必须
// 为类型定义别名,否则无法进行后续操作
typedef unsigned short int USI;
typedef unsigned long int ULI;
//02.C语言重要知识点概括:
// 补码-->递归-->逻辑
// 数组-->二维数组地图-->排序
// 指针-->外挂(函数指针)
// 字符串-->结构体-->内存四区-->文件
//03.CPP语言当中获取类型的方式:
// typeid(var).name();
// 根据变量名称获取变量的所属类型;
// 并且将该数据类型以字符串的形式打印出来
int main01(void)
{
unsigned long int num = 10;
ULI ulinum = 10;
printf("%s \n", typeid(ulinum).name());//typedef(x).name();根据变量名称获取变量所属的数据类型(字符串表现形式)
system("pause");
}
20160130.CCPP体系详解(0009天)的更多相关文章
- 20160129.CCPP体系详解(0008天)
程序片段(01):函数.c+call.c+测试.cpp 内容概要:函数 ///函数.c #include <stdio.h> #include <stdlib.h> //01. ...
- 20160226.CCPP体系详解(0036天)
程序片段(01):01.多线程.c+02.多线程操作.c 内容概要:多线程 ///01.多线程.c #include <stdio.h> #include <stdlib.h> ...
- 20160208.CCPP体系详解(0018天)
程序片段(01):main.c 内容概要:PointWithOutInit #include <stdio.h> #include <stdlib.h> //01.野指针详解: ...
- 20160206.CCPP体系详解(0016天)
代码片段(01):.指针.c+02.间接赋值.c 内容概要:内存 ///01.指针 #include <stdio.h> #include <stdlib.h> //01.取地 ...
- 20160205.CCPP体系详解(0015天)
程序片段(01):01.杨辉三角.c 内容概要:杨辉三角 #include <stdio.h> #include <stdlib.h> #define N 10 //01.杨辉 ...
- 20160204.CCPP体系详解(0014天)
程序片段(01):define.h+data.h&data.c+control.h&control.c+view.h&view.c+AI.h&AI.c+main.c 内 ...
- 20160203.CCPP体系详解(0013天)
程序片段(01):数组.c+02.数组初始化语法.c 内容概要:数组 ///01.数组.c #include <stdio.h> #include <stdlib.h> //0 ...
- 20160128.CCPP体系详解(0007天)
以下内容有所摘取,进行了某些整理和补充 论浮点数的存储原理:float浮点数与double浮点数的二进制存储原理–>阶码 浮点数转二进制 1.整数int类型和浮点数float类型都是占用4个字节 ...
- 20160127.CCPP体系详解(0006天)
程序片段(01):msg.c 内容概要:线程概念 #include <stdio.h> #include <stdlib.h> #include <Windows.h&g ...
随机推荐
- ZOJ 3555 Ice Climber(dp)
晦涩的题意+各种傻逼害我调了那么久,实际上题目就是一个dp[i][j],dp[i][j]表示第i层第j个最少需要多少时间,当我们去更新dp[i][j]的时候,考虑的是从第i+1层的某一个dp[i+1] ...
- C++堆栈与函数调用
一.C++程序内存分配 1)在栈上创建.在执行函数时,函数内局部变量的存储单元都在栈上创建,函数结束是,这些存储单元自动被释放.栈内存的分配运算内置于处理器的指令集中,一般采用寄存器来存取,效率很高但 ...
- mysql 存储过程事务支持回滚
如图查看表的属性: InnoDB 支持事务. MyISAM 不支持事务,不过性能更优越.
- Baidu和Google搜索引擎使用技巧(转)
转自:Baidu和Google搜索 http://www.douban.com/note/261208979/ 百度搜索一:基本搜索 二:高级搜索 谷歌搜索一:基本搜索1)可部分匹配也可完全匹 ...
- HTTP常用的状态码
一.200状态码: 成功2××:成功处理了请求的状态码. 1.200 :服务器已成功处理了请求并提供了请求的网页. 2.204:服务器成功处理了请求,但没有返回任何内容. 二.300状态码: 重定向3 ...
- WebSocket API简介
WebSocket是html5新增加的一种通信协议,目前流行的浏览器都支持这个协议,例如Chrome,Safari,Firefox,Opera,IE等等,对该协议支持最早的应该是chrome,从chr ...
- Android 图片异步加载的体会,SoftReference已经不再适用
在网络上搜索Android图片异步加载的相关文章,目前大部分提到的解决方案,都是采用Map<String, SoftReference<Drawable>> 这样软引用的 ...
- servlet学习笔记一
Servlet一.基本概念 我们的程序根据是否需要访问网络,可分为网络程序和非网络程序.而 网络程序又分为B/S结构和C/S结构. 什么是C/S?即客户端(Client)/服务器(Server)模式. ...
- <iostream> 和 <iostream.h>的区别 及 Linux下编译iostream.h的方法
0.序言 其实2者主要的区别就是iostream是C++标准的输入输出流头文件,而iostream.h是非标准的头文件. 标准头文件iostream中的函数属于标准命令空间,而iostream.h中的 ...
- LoadRunner8 安装步骤
一.介绍 LoadRunner,是一种预测系统行为和性能的负载测试工具.通过以模拟上千万用户实施并发负载及实时性能监测的方式来确认和查找问题,LoadRunner能够对整个企业架构进行测试.企业使用L ...