大学生必备C语言基础练习题目来了(三)(建议收藏哦)❤️

简介: 大学生必备C语言基础练习题目来了(三)(建议收藏哦)❤️

题目1. 已有一个按升序排好的整型数组,要求输入一个数,查找数组中是否有此数;若有,将其删除;若没有,输出”Not exists!”。编写一个程序实现。

流程图:

实现代码:

#include<stdio.h>
int n, i, j = 0,
a[10] = { 1,2,3,4,5,6,7,8 };
void delet(int s)
{
  for (s; s < 8; s++)
  {
    a[s] = a[s + 1];
  }
}
int main()
{
  printf("请输入n的值¦:");
  scanf("%d", &n);
  for (i = 0; i < 8; i++)
  {
    if (n == a[i])
    {
      delet(i);
      for (i = 0; i < 7; i++)
      {
        printf("%d ", a[i]);
      }
      printf("\n");
    }
    else
    {
      j++;
      if (j == 8)
        printf("Not exsits \n");
    }
  }
}

运行结果:

题目2.编写一个程序,将数组a[4][4]中的元素行列互换后存放在本数组中。

流程图:

实现代码:

#include<stdio.h>
void main()
{
  int a[4][4] = {{1,2,4,5},{ 4,5,8,7},{9,6,4,3},{ 7,8,9,0}};      
  int i,j,b[4][4];
  printf("原数组:\n");  
  for(i = 0; i < 4; i++)
  {
    for(j = 0; j < 4; j++)
    {
      printf("%4d ",a[i][j]);
    }
     printf("\n");
  }
  for(i = 0; i < 4; i++)
  {
    for(j = 0; j < 4; j++)
    {
      b[j][i]=a[i][j];   //行列互换
    }
  }
  for(i = 0; i < 4; i++)
  {
    for(j = 0; j < 4; j++)
    {
      a[i][j] = b[i][j];
    }
  }
  printf("\n");
  printf("行列互换后的数组:\n");   
  for(i = 0; i < 4; i++)
  {
    for(j = 0; j < 4; j++)
    {
      printf("%4d ",a[i][j]);
    }
     printf("\n");
  }
}

运行结果:
题目3. 编写一个程序,输出杨辉三角前10行。

流程图:

实现代码:

#include <stdio.h>
#define N 10
void main()
{
    int i, j, k, n = 10, a[N][N];  
    printf("10行杨辉三角如下:\n");
    for(i = 1; i < n; i++)
        a[i][1] = a[i][i] = 1;  
    for(i = 3; i <= n; i++)
        for(j = 2; j <= i-1; j++)
            a[i][j] = a[i-1][j-1] + a[i-1][j];    
for(i = 1; i <= n; i++){
        for(k = 1; k <= n-i; k++)
            printf("   ");  
        for(j = 1; j <= i; j++) 
            printf("%6d",a[i][j]);   
        printf("\n");  
    }
    printf("\n");
}

运行结果:
题目4. 编写一个程序,判断一个字符串是否回文。回文就是顺读和逆读都相同,如字符串’abcba’就是回文。

流程图:

实现代码:

#include <stdio.h>
#include <string.h>
void main(){
    char s[100];  // 存放输入的字符串
    int i, j, n;
    printf("输入字符串:");
scanf("%s",s); 
    n=strlen(s);
    for(i=0,j=n-1;i<j;i++,j--)
        if(s[i]!=s[j]) break;
        if(i>=j)
            printf("是回文串\n");
        else
            printf("不是回文串\n");
}

运行结果:

目录
相关文章
|
3月前
|
算法 C语言 容器
从C语言到C++_18(stack和queue的常用函数+相关练习)力扣(上)
从C语言到C++_18(stack和queue的常用函数+相关练习)力扣
33 0
|
3月前
|
C语言
C语言指针——练习
C语言指针——练习
|
5天前
|
存储 编译器 C语言
【C语言】指针练习题目
【C语言】指针练习题目
|
2月前
|
C语言
C语言练习代码第一篇
C语言练习代码第一篇
|
2月前
|
测试技术 C语言
数据结构学习记录——树习题—Tree Traversals Again(题目描述、输入输出示例、解题思路、解题方法C语言、解析)
数据结构学习记录——树习题—Tree Traversals Again(题目描述、输入输出示例、解题思路、解题方法C语言、解析)
31 1
|
2月前
|
C语言
|
2月前
|
编译器 C语言
|
2月前
|
C语言
|
3月前
|
存储 前端开发 算法
从C语言到C++_18(stack和queue的常用函数+相关练习)力扣(下)
从C语言到C++_18(stack和queue的常用函数+相关练习)力扣
13 0
|
2月前
|
C语言
c语言循环题目
c语言循环题目