C语言基础代码

 #include <stdio.h>
#include <string.h>
  void valueTwoNumber(int *a,int *b){   
int temp;
temp = *a;
*a = *b;
*b = temp;  
}

void valueTwoString(char **str,char **str1){

char *temp;
temp = *str;
*str = *str1;
*str1 = temp;
}

//函数:对一个数组进行排序
void sortArray(int a[],int n){
int i,j;    
int temp = 0;
for(i = 0;i < n;i++){
    for(j = 0;j < n-1-i;j++){
        if(a[j] < a[j+1]){
            temp = a[j];
            a[j] = a[j+1];
            a[j+1] = temp;
        }
    }
}
for(i = 0;i < n;i++){
    printf("%d\n",a[i]);
  } 
} 

//写函数:实现数组中能同时被2和3整除的数的和 
//找出这个同时能被2和3整除的数的个数并返还 
int sumArray(int a[],int n,int *count){

int i,sum = 0;
*count = 0;
for(i = 0;i < n;i++){
    
    if(a[i] % 2==0&&a[i]%3==0){
        
        sum +=a[i];
        (*count)++;
    }
}
return sum;

} 
/*
构造函数要点:
1、首先需要了解函数的实现功能 
2、判断函数是否有返回值
3、针对参数传递时,遵守尽量简洁方便、灵活, 
*/
//构造一个函数:比较两个字符串的大小,并返还大的字符串 
char *compareTwoString(char *str,char *str1){
int k;
k = strcmp(str,str1);
if(k == 0){
    return str;
}else if(k < 0){
    
    return str1;
}else{
    
    return str;
  } 
}

//构造一个函数:比较两个字符串的大小,并返还大的字符串 
char *compareTwoStr(char *str,char *str1){
int n;
n = strcmp(str,str1);
if(n == 0){
    return str;
}else if(n < 0){
    
    return str1;
}else {
    return str;
  } 
}
//构造一个函数:判断一个字符在这个字符串里边?
int judgeCharInString(char *str,char ch){

int n = 0;
char *s1 = NULL;
s1 = strchr(str,ch);
if(s1 !=NULL){
    n = 1;
}else{
    n = 0;
 }  
    return n;
} 

int  judgeStringInString(char *str,char *str1){

char *s;
s = strstr(str,str1);
if(s != NULL){
    return 1;
}else{
    
    return 0;
}
}

//构造一个指针函数,通过返还一个指针得到两个整数的和
int *backTwoNumberSum(int a,int b){

int *p; 
int sum = 0;
sum = a + b;
p = &sum;   
return p;

}
//函数指针 
/*
int (*sum)(int a,int b){

}
*/
//sum  sum1;

typedef (*SumTwoNumber)(int a,int b);//SumTwoNumber是函数指针类  型名称 
int sumNumber(int a,int b)
{
return a+b;
}
int chengNumber(int a,int b){

return a * b;
}

//构造一个函数,求1+2+3+---+100的和
int sumOneToThoud(int n){
if(n == 1){
    return 1;
}else{
    return n+sumOneToThoud(n-1);
}   
} 
//通过使用递归函数,求100以内能被2  3  5  同时整除的数

int valueToThous(int n){

if(n == 1){
    return 0;
}   
if(n % 12 == 0){
    printf("%d\n",n);
    
}
return valueToThous(n-1);   
} 

 //使用递归函数,求任何数的阶乘 5! = 5 *4*3*2*1=120
 int jiecheng(int n){

if(n == 1)return 1;
else return n * jiecheng(n-1);

 } 

 int backArrayBigValue(int a[],int n){
int max = a[0];
int i;
for(i = 0; i < n;i++){
    if(max < a[i])
    max = a[i];
 }  
return max; 
 }

//abcdef   fedcba
char *stringBackString(char str[],int n){
char *p = NULL,*q = NULL;
char s;
p = str;
q = str + n-1;
while(p < q){
    s = *p;
    *p = *q;
    *q = s;
    p++;
    q--;        
}
printf("%s\n",str);
return str; 
}

int main(int argc, char **argv)
{

int a[] = {
    7,8,45,123,458,1655,87895
};
int sum = backArrayBigValue(a,sizeof(a)/sizeof(int));
printf("sum = %d\n",sum);
char str[] = "helloworld";
int n = strlen(str);
char *s; 
s = stringBackString(str,n);
printf("%s\n",*s);


int a = 5;
int  sum = jiecheng(20);
printf("sum = %d\n",sum);

int backSum = 0; 
SumTwoNumber sum;//创建一个函数指针变量 
sum = sumNumber;//为函数指针变量赋值,这个值就是地址,就是函数的名称,就是函数的入口
backSum = (*sum)(10,20);
printf("%d\n",backSum);


int sum = 0;
sum = sumOneToThoud(5);
printf("sum = %d\n",sum);*/


int n = valueToThous(100);



//数组和函数之间的关系
//数组作为形参传递

int a[] = {65,99,12,36,45,67};
int n,count,sum = 0;
n = sizeof(a)/sizeof(int);
printf("n = %d\n",n);
sum = sumArray(a,n,&count); 
printf("count = %d sum = %d\n",count,sum);


char *str = "helloworld";
char *str1 = "iiiiii";
char *p;
p = compareTwoStr(str,str1);
printf("%s\n",p);

char *str = "adfasdfsadfsadf";
char ch ='d';
int n;
n = judgeCharInString(str,ch);
if(n == 1){
    printf("找到了\n");
}else{
    printf("没有找到\n");
} 


char *str = "mynameisjack";
char  *str1 = "jack";
int n;
n = judgeStringInString(str,str1);
if(n == 1){
    
    printf("找到了\n");
}else{
    
    printf("没有找到\n");
}


    数据类型 * 函数的名称(形参){
        
        语句块; 
    
        return  指针; 
    } 



int a = 20;
int b = 30;
int *sum;
sum = backTwoNumberSum(a,b);
printf("sum = %d\n",*sum);


//递归函数


    函数本身调用函数本身,但是总会有一个条件出口,从而结束该函数调用。 
    
return 0;
}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,372评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,368评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,415评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,157评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,171评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,125评论 1 297
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,028评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,887评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,310评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,533评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,690评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,411评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,004评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,659评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,812评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,693评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,577评论 2 353

推荐阅读更多精彩内容