【C语言】期末总结C_code

又到期末了,啪啪啪写起了代码。。。

#include "stdio.h"
#include "math.h"
#include "ctype.h"
#include "string.h"
#include "stdlib.h"
#include "time.h"

/*************************

 符号常量

**************************/
#define PI 3.1415926

const double PI_=3.1415926; //注意格式区别

/*************************

   枚举类型变量

**************************/
enum week {mon, tue, wed, thu, fri, sat, sun};   //mon=0,tue=1,...
//enum week {mon=1, tue, wed, thu, fri, sat, sun};

/*************************

   结构体类型变量

**************************/
struct Point
{
 double x,y;
};
typedef Point pit;

typedef struct{ double x,y; } pit_;
//可以嵌套

int max_thr(int a, int b, int c);
int is_leap(int x);
int is_prime1(int x);
int is_prime2(int x);
int fac(int n);
int com_factor(int m, int n);
void swap_a_b(int *p,int *q);
void mp_sort(int *a,int n);
void slt_sort(int *a,int n);
double dist(pit a, pit b);

int main()
{
 /*****************************************

 基本输入输出(注意输出结果区别)

 ******************************************/
 float a1; double a2;
 //scanf("%f %lf",a1,a2);
 
 int b1=2016;
 printf("%8d\n",b1);  //右对齐,左补空格
 printf("%-8d\n",b1); //左对齐
 printf("%08d\n",b1); //右对齐,左补0
 
 printf("%.2f\n",PI);
 printf("%1.2f\n",PI);
 printf("%8.2f\n",PI);
 printf("%-8.2f\n",PI);

 printf("%d\n",8/5);     //整数/整数=整数
 printf("%.2f\n",8/5);
 printf("%.2f\n",(float)8/5);//强类型转换
 printf("%.2f\n",8.0/5); //浮点数/整数=浮点数
 printf("%.2f\n",8.0/5); //浮点数/浮点数=浮点数

 printf("\\\t\"\n");

 /************************************************************

 比较float和double类型数据,
 因为float/double精度问题,
 比如 1.000000001 可能和1.0000000000001相等
 
 比较 > 、< 可以直接进行比较
 比较 == 、!= 最好用两个数做差取绝对值跟指定的精度进行比较

 *************************************************************/
 float c1=0.0000000001,c2=0.0000000001;
 if(fabs(c1-c2) < 1e-10) printf("c1 == c2\n");

 /*************************************

 交换变量

 t = a; a = b; b = t; //使用范围广

 a = a + b;
 b = a - b;
 a = a - b;

 swap( &a, &b);

 **************************************/

 /*************************

 switch语句

 **************************/
 int d=3;
 switch(d)
 {
 case 1: d=0;break;
 case 2: d=1;break;
 default:d=2;break;
 }

 /*************************

 产生随机数( 1 ~ 100 )

 **************************/
 int rand_num;
 srand(time( NULL));
 rand_num = rand() % 100 +1;

 /*************************

 数组清零
 #include "string.h"
 memset(a, 0, sizeof(a));

 **************************/

 
 /*************************

 字符函数
 getchar( ch);
 putchar( ch);

 **************************/
 char ch1 = 'a';
 if( isalpha( ch1) ) printf("%c is a char\n", ch1);
 if( isdigit( ch1) ) ;

 /*************************

 字符串函数

 gets( str);
 puts( str);

 **************************/
 char str[100],s1[100]={'a'},s2[100]="asdfgh";
 sprintf(str,"%s","asd2016");
 printf("%s\n",str);

 int len = strlen( str);
 strcpy(s1, s2);
 strcmp(s1, s2); //s1>s2,返回值>0;s1==s2,返回值=0;s1b?a:b) > c ? (a>b?a:b) : c;
}

/*************************

 判断闰年

**************************/
int is_leap(int x)
{
 if((x%4==0 && x%100!=0) || x%400==0)
 return 1;
 else
 return 0;
}

/*************************

 判断素数 1

**************************/
int is_prime1(int x)
{
 int i;
 if(i <= 1) return 0;
 for(i = 2; i*i<=x; i++)
 if(x % i == 0) return 0;
 return 1;
}

/*************************

 判断素数 2
 #include "math.h"

**************************/
int is_prime2(int x)
{
 int i,m;
 if(x <= 1) return 0;
 m = floor(sqrt(x) + 0.5);
 for(i = 2; i <= m; i++)
 if(x % i == 0) return 0;
 return 1;
}

/*************************

 计算最大公约数

**************************/
int com_factor(int m, int n)
{
 int r,t;
 if(m < n) {t=m; m=n; n=t;}
 r = m % n;
 while(r != 0)
 {
 m = n;
 n = r;
 r = m % n;
 }
 return n;
}

/*************************

 交换变量

**************************/
void swap_a_b(int *p,int *q)
{
 int t;
 t = *p; *p = *q; *q = t;
 //下面是错误方法
 //int *t;
 //t = p; p = q; q = t;
}

/*************************

 计算两点间距离
 #include "math.h"

**************************/
double dist(pit a, pit b)
{
 return hypot(a.x-b.x, a.y-b.y);
}

/*************************

 冒泡排序

**************************/
void mp_sort(int *a,int n)
{
 int i,j,t;
 for(i=0;ia[j])
 { t=a[i];a[i]=a[j];a[j]=t;}
}

/*************************

 选择排序

**************************/
void slt_sort(int *a,int n)
{
 int i,j,k,t;
 for(i=0;i

你可能感兴趣的:(【C语言】期末总结C_code)