c语言基础题2

简介: c语言基础题2

 (创作不易,感谢有你,你的支持,就是我前行的最大动力,如果看完对你有帮助,请留下您的足迹)

第一题:三位数

有1、2、3、4四个数字,可以组成多少个互不相同且无重复数字的三位数?都是多少?

思路:首先创建三个变量分别表示三位数的个位,十位,百位,在创建一个变量用于计数

int a, b, c;//首先创建三个变量分别表示三位数的个位,十位,百位
int sum = 0;//用于计数

//接着用for循环对三位数进行输出

for (a = 1; a < 5; a++)//确保三位数都在1-4之内
    {
        for (b = 1; b < 5; b++)
        {
            for (c = 1; c < 5; c++)
            {
 //因为三位数各不相同,所以用if语句进行判断
                if (a != b && b != c && a != c)
                {
                    printf("%d%d%d\n", a, b, c);
                    sum++;
                }

总代码如下:

#include<stdio.h>
int main()
{
  int a, b, c;//首先创建三个变量分别表示三位数的个位,十位,百位
  int sum = 0;//用于计数
  //接着用for循环对三位数进行输出
  for (a = 1; a < 5; a++)//确保三位数都在1-4之内
  {
    for (b = 1; b < 5; b++)
    {
      for (c = 1; c < 5; c++)
      {
        //因为三位数各不相同,所以用if语句进行判断
        if (a != b && b != c && a != c)
        {
          printf("%d%d%d\n", a, b, c);
          sum++;
        }
      }
    }
  }
  printf("sum = %d", sum);
  return 0;
}

第二题 :菱形

思路:我们可以将菱形分为上下两个部分进行打印

先创建变量,确定要打印菱形的行数

int a = 0;
scanf("%d", &a);//行数

先打印上半部分

int b = 0;
for (b = 0; b < a; b++)
    {
        int c = 0;
        int d = 0;
        for (c = 0; c < a-b-1; c++)//确定每一行空格数量
        {
            printf(" ", c);//打印空格
        }
        for (d = 0; d < 2 * b + 1; d++)//确定每一行*数量
        {
            printf("*", d);//打印*
        }
        printf("\n");
    }

  再打印下半部分

int e = 0;
for (e = 0; e < a - 1; e++)
    {
        int i = 0;
        int p = 0;
        for (i = 0; i <=e; i++)
        {
            printf(" ", i);
        }
        for (p = 0; p < 2*(a-e-1) - 1; p++)
        {
            printf("*", p);
        }
        printf("\n");
    }

总代码如下

#include<stdio.h>
//    *
//   ***
//  *****
// ******* 
//  *****
//   ***
//    *
int main()
{
  int a = 0;
  scanf("%d", &a);//行数
  int b = 0;
  int e = 0;
  //先打印上半部分
  for (b = 0; b < a; b++)
  {
    int c = 0;
    int d = 0;
    for (c = 0; c < a-b-1; c++)
    {
      printf(" ", c);//打印空格
    }
    for (d = 0; d < 2 * b + 1; d++)
    {
      printf("*", d);//打印*
    }
    printf("\n");
  }
  //再打印下半部分
  for (e = 0; e < a - 1; e++)
  {
    int i = 0;
    int p = 0;
    for (i = 0; i <=e; i++)
    {
      printf(" ", i);
    }
    for (p = 0; p < 2*(a-e-1) - 1; p++)
    {
      printf("*", p);
    }
    printf("\n");
  }
  return 0;
}

第三题:猜数字

要求我们制作一个100以内猜数字的游戏,根据系统提示,直到猜到准确数字

先创建一个随机数,作为我们要猜的数字

int c = 0;
int guess = 0;
c = rand() % 100 + 1;

注意!为了防止每一次系统给出的随机值都相同,这里我们需要创建一个随机数种子

srand((unsigned int)time(NULL));

然后用while循环判断我们猜的数字与电脑给的数字之间的关系

while (1)
    {
        printf("请输入猜想值");
        scanf("%d", &guess);
        if (guess > c)
        {
            printf("小于猜想值\n");
        }
        else if (guess < c)
        {
            printf("大于猜想值\n");
        }
        else if (guess == c)
        {
            printf("答对啦\n");
            break;
        }
    }

现在游戏的基本框架已经搭建好了,接下来就是一系列优化

总代码如下

#include<stdio.h>
#include<stdlib.h>
#include<time.h>
void a()
{
  printf("1.play  0.exit\n");
}
void game()
{
  int c = 0;
  int guess = 0;
  c = rand() % 100 + 1;
  while (1)
  {
    printf("请输入猜想值");
    scanf("%d", &guess);
    if (guess > c)
    {
      printf("小于猜想值\n");
    }
    else if (guess < c)
    {
      printf("大于猜想值\n");
    }
    else if (guess == c)
    {
      printf("答对啦\n");
      break;
    }
  }
}
int main()
{
  int b = 0;
  srand((unsigned int)time(NULL));//创建随机数种子,使每一次的随机数都不一样
  do
  {
    a();
    printf("请选择>:");
    scanf("%d", &b);
    switch(b)
    {
    case 1:
      game();
      break;
    case 0:
      printf("退出游戏\n");
      break;
    default:
      printf("输入错误\n");
      break;
    }
  } while (b);
  return 0;
}
相关文章
|
JavaScript
Vue中如何设置在执行删除等危险操作时给用户提示(二次确认后执行对应的操作)
这篇文章介绍了在Vue项目中如何实现执行删除等危险操作时的二次确认机制,使用Element UI的`el-popconfirm`组件来弹出确认框,确保用户在二次确认后才会执行删除操作。
Vue中如何设置在执行删除等危险操作时给用户提示(二次确认后执行对应的操作)
|
7月前
|
关系型数据库 虚拟化 UED
Omnissa Horizon Windows OS Optimization Tool 2503 - Windows 系统映像优化工具
Omnissa Horizon Windows OS Optimization Tool 2503 - Windows 系统映像优化工具
308 7
Omnissa Horizon Windows OS Optimization Tool 2503 - Windows 系统映像优化工具
|
8月前
|
人工智能 TensorFlow 算法框架/工具
《探索AI与鸿蒙融合的开源宝藏:这些框架你不能错过》
人工智能(AI)与鸿蒙系统的集成开发正引领技术创新潮流,为用户带来更智能、流畅的体验。华为HiAI作为鸿蒙AI生态的核心引擎,提供计算机视觉、语音识别等多领域支持,实现设备间协同共享;TensorFlow Lite for Microcontrollers专为资源受限的物联网设备优化,助力轻量级AI模型运行;MindSpore Lite适合移动和边缘设备,具备高效推理性能;OpenCV for HarmonyOS则在计算机视觉领域大放异彩,赋能图像处理和视频分析。这些开源框架各具优势,为开发者提供了强大工具,推动AI与鸿蒙生态繁荣发展。
395 13
|
9月前
|
机器学习/深度学习 编解码 TensorFlow
YOLOv11改进策略【模型轻量化】| 替换骨干网络为EfficientNet v1 高效的移动倒置瓶颈结构
YOLOv11改进策略【模型轻量化】| 替换骨干网络为EfficientNet v1 高效的移动倒置瓶颈结构
500 14
YOLOv11改进策略【模型轻量化】| 替换骨干网络为EfficientNet v1 高效的移动倒置瓶颈结构
|
7月前
|
数据采集 人工智能 自动驾驶
AI大模型都有的“幻觉病”,企业AI应用创新路上须警惕
法思诺创新提醒:AI大模型虽强大,但其“幻觉病”不容忽视。文章剖析了AI生成错误信息的现象及其成因,包括数据质量问题、缺乏常识理解及追求流畅度的倾向,并警示企业在医疗、法律、金融等关键领域应用AI时需警惕潜在风险。为应对挑战,应通过技术改进、人机协同和伦理规范三重手段约束AI行为,同时强调企业应以人为主导,将AI作为辅助工具,在享受技术便利的同时有效控制风险。
352 0
|
存储 自然语言处理 安全
C++ STL标准库 《string原理与实战分析》
C++ STL标准库 《string原理与实战分析》
329 0
|
存储 安全 网络协议
Elasticsearch 配置文件解析
【10月更文挑战第3天】Elasticsearch 配置文件解析
393 3
|
机器学习/深度学习 消息中间件 人工智能
人工智能平台PAI产品使用合集之vLLM是否支持模型长度扩展
阿里云人工智能平台PAI是一个功能强大、易于使用的AI开发平台,旨在降低AI开发门槛,加速创新,助力企业和开发者高效构建、部署和管理人工智能应用。其中包含了一系列相互协同的产品与服务,共同构成一个完整的人工智能开发与应用生态系统。以下是对PAI产品使用合集的概述,涵盖数据处理、模型开发、训练加速、模型部署及管理等多个环节。
|
容器
RT-Thread快速入门-事件集
RT-Thread快速入门-事件集
285 0
|
安全 编译器 C语言
一文讲清楚内联函数 inline
在C语言中,如果一些函数被频繁调用,不断地有函数入栈,即函数栈,会造成栈空间或栈内存的大量消耗。 为了解决这个问题,特别的引入了inline修饰符,表示为内联函数。