C实训(三)

2019-12-08 20:15栏目:bob体育平台
TAG:

char a[5] = { 12,36,96,128,182 };

作业:

1.随机输入一个年份,判断该年份是否是闰年?如果是闰年,则输出该年是闰年,否则输出该年不是闰年。
满足闰年的条件:

  • 能被400整除。(如2000年是闰年,1900年不是闰年)。
  • 能被4整除,但是不能被100整除。(如2004年就是闰年,2010年不是闰年).
int year = 0;
    printf("请输入一个年份:");
    scanf("%d",&year);
    if ((year % 400 == 0) || (year % 4 == 0 && year % 100 != 0)) {
        printf("%d是闰年n",year);
    } else {
        printf("%d不是闰年n",year);
    }

2.已知abc+cba = 1333,其中a、b、c均为一位数,编程求出满足条件的a、b、c所有组合。

for (int a = 1; a < 10; a++) {
        for (int b = 0; b < 10; b++) {
            for (int c = 1; c < 10; c++) {
                if ((a * 100 + b * 10 + c * 1) + (c * 100 + b * 10 + a * 1 == 1333)) {
                    printf("%d,%d,%dn",a,b,c);
                }
            }
        }
    }

3.随机产生20个10~50的正整数存放到数组中,并求数组中的最大值,最小值,平均值及各个元素之和

    int num[20];
    int max = 0;
    int min = 0;
    int avr = 0;
    int sum = 0;
    for (int i = 0; i < 20 - 1; i++) {
        num[i] = arc4random() % (50 - 10 + 1) + 10;
        max = max > num[i] ? max : num[i];
        min = min < num[i] ? min : num[i];
        avr = num[i]/20;
        sum+=num[i];
    }
    printf("最大值为:%dn",max);
    printf("最小值为:%dn",min);
    printf("平均值为:%dn",avr);
    printf("元素和为:%dn",sum);

4.编写一个程序,输入两个包含5个元素的数组,先将两个数组升序排列,然后将这两个数组合并成一个升序数组

int arr1[] = {1, 5, 8, 14, 7};
    int arr2[] = {3, 6, 34, 29, 4};
    int arr3[11] = {};
    BOOL flag = YES;
    for (int j = 0; j < 5 - 1; j++) {
        flag = NO;
        for (int i = 0; i < 5 - 1 - j; i++) {
            if (arr1[i] > arr1[i + 1]) {
                int temp = arr1[i + 1];
                arr1[i + 1] = arr1[i];
                arr1[i] = temp;
                flag = YES;
            }
        }
    }
    for (int i = 0; i < 5; i++) {
        printf("数组一:%dn",arr1[i]);
    }



    for (int j = 0; j < 5 - 1; j++) {
        flag = NO;
        for (int i = 0; i < 5 - 1 - j; i++) {
            if (arr2[i] > arr2[i + 1]) {
                int temp = arr2[i + 1];
                arr2[i + 1] = arr2[i];
                arr2[i] = temp;
                flag = YES;
            }
        }
    }
    for (int i = 0; i < 5; i++) {
        printf("数组二:%dn",arr2[i]);
    }



    for (int i = 0; i < 5; i++) {
        arr3[i] = arr1[i];
        arr3[i] = arr2[i - 5];
    }
    for (int j = 0; j < 10 - 1; j++) {
        flag = NO;
        for (int i = 0; i < 10 - 1 - j; i++) {
            if (arr3[i] > arr3[i + 1]) {
                int temp = arr3[i + 1];
                arr3[i + 1] = arr3[i];
                arr3[i] = temp;
                flag = YES;
            }
        }
    }
    for (int i = 0; i < 10; i++) {
        printf("数组三:%dn",arr3[i]);
    }

5.给定某年某月某日,输出其为这一年的第几天

    int dayArr[] = {31, 28, 31, 28, 31, 30, 31, 31, 29, 31, 30, 31}; //先确定每个月有多少天
    int year1 = 0;
    int month = 0;
    int day = 0;
    printf("请输入一个年份:");
        scanf("%d",&year);
        if ((year1 % 400 == 0) || (year1 % 4 == 0 && year1 % 100 != 0)) {
            printf("%d是闰年n",year1);
            dayArr[2] = 29;
        }
    for (int i = 0; i < month - 1; i++) {
        day += dayArr[i];
    }
    printf("第%dn天",day + month);

6.编写整型数组排序程序(冒泡排序-升序)

    int array[] = {2,56,97,23,17,7,45};
    BOOL f = YES;
    for (int j = 0; j < 7 - 1; j++) {
        f = NO;
        for (int i = 0; i < 7 - 1 - j; i++) {
            if (array[i] < array[i + 1]) {
                int temp = array[i + 1];
                array[i + 1] = array[i];
                array[i] = temp;
                f = YES;
            }
        }
    }

    for (int i = 0; i < 7; i++) {
        printf("%d",array[i]);
    }

7.找出下列整型数组中的最大和最小值及其所在位置的下标i
int a[] = {5, -9, 32, 77, 64, -24, 14, 0, 21, 45};

    int a[] = {5, -9, 32, 77, 64, -24, 14, 0, 21, 45};
    int max1 = 0;
    int min1 = 0;
    int maxIndex = 0;
    int minIndex = 0;
    for (int i = 0; i < 10 - 1; i++) {
        if (max1 < a[i]) {
            max1 = a[i];
            maxIndex = i;
        }

    }

    for (int i = 0; i < 10 - 1; i++) {
        if (min1 > a[i]) {
            min1 = a[i];
            minIndex = i;
        }
    }
    printf("最大值是:%dn,最小值是:%dn",max1,min1);
    printf("最大值所在位置的下标是:%dn,最小值所在的下标是:%dn",maxIndex,minIndex);

8.把 str1, str2, str3 合并到 result 数组中。
char result[50] = {0};
char str1[] = "Lanou ";
char str2[] = "23_class ";
char str3[] = " is niu best!";
结果:“Lanou 23_class is niu best!”

char result[50] = {0};
    char str1[] = "Lanou ";
    char str2[] = "23_class ";
    char str3[] = " is niu best!";
    strcat(str1, str2);
    strcat(str1, str3);
    strcat(result, str1);
    printf("%sn",result);

9.删除字符串中含有0-9的数字

char str[] = "a34sf5slvjxz2g";
  int count = 0;
  int index = 0;  //记录位置
  while (str[count] != '') {
      if ('0' <= str[count] && str[count] <= '9') {
          count++;
          continue; //往下继续遍历
      }
      str[index] = str[count];
      index++;
      count++;
  }
  str[index] = '';
  printf("%sn",str);

int[] a; //int型的一维数组

 a[]范围为0~256. 数组中数都有效。

知识点:

1.数组

1️⃣数组:
  由相同数据类型组成的构造类型,每个成员称为一个数组元素。
  最简单的数组是一维数组。
2️⃣定义:
  类型说明符 数组名[常量表达式] = {值1,值2...};
一维数组定义:
  数据类型 数组名称[元素个数];
  int arges = [10];
3️⃣数组初始化:
  数组元素的访问:数组名 + 下标
4️⃣数组下标:数组元素在数组中的序号。
5️⃣下标可以是常量,也可以是变量。
6️⃣访问数组中的元素下标可以为变量。
7️⃣访问数组中的所有元素叫遍历。
8️⃣系统不会检测数组元素的下标是否越界,编程时,必须保证数组下标不能越界。
9️⃣不能这样定义数组:
  int array[] = {}; 或者 int array[2] = {1, 2, 3};

版权声明:本文由bob体育app发布于bob体育平台,转载请注明出处:C实训(三)