c/c++快乐算法第三天

yizhihongxing

c/c++感受算法快乐(3)

开始时间2023-04-16 22:21:10

结束时间2023-04-17 00:09:34

前言:很好,这周就要结束了,大家都回学校了么,嘻嘻。回顾一下昨天的算法题,1.4抓交通肇事犯运用枚举模拟,1.5兔子产子问题运用迭代循环,1.6牛顿迭代法求方程根迭代循环,1.7最佳存款问题迭代循环。什么是迭代?对计算机特定程序中需要反复执行的子程序(一组指令),进行一次重复,即重复执行程序中的循环,直到满足某条件为止,亦称为迭代。快来看看今天的问题叭!

第一章 趣味算法入门

第八题 冒泡排序

一.问题描述

c/c++快乐算法第三天

 二.设计思路

  有输入,并且为自行输入的n个整数序列。这里我们需要用到冒泡排序,冒泡排序是什么?它重复地走访过要排序的元素列,依次比较两个相邻的元素,如果他们的顺序(如从大到小、首字母从A到Z)错误就把他们交换过来。走访元素的工作是重复地进行直到没有相邻元素需要交换,也就是说该元素已经排序完成,如同汽水中的气泡最终会冒到顶部一样顾名冒泡排序。冒泡排序总的平均时间复杂度为c/c++快乐算法第三天,冒泡排序是一种稳定排序算法。升序排列为数据从小到大排列。

c/c++快乐算法第三天

 三.流程图

c/c++快乐算法第三天

 四.源代码

#include<stdio.h>
int main()
{
    int n;
    scanf("%d",&n);
    int a[n];
    int i=0,j=0,temp;
    for(i=0;i<n;i++)
    {
        scanf("%d",&a[i]);
    }
    for(i=1;i<n;i++)
    {
        for(j=0;j<n-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\t",a[i]);
    }
    return 0;
}

 

五.运行结果

c/c++快乐算法第三天

 第九题 折半查找

一.问题描述

c/c++快乐算法第三天

 二.设计思路

  

c/c++快乐算法第三天

三.流程图

c/c++快乐算法第三天

 四.源代码

#include<stdio.h>
int main()
{
    int arr[]={3,4,10,13,33,42,46,63,76,78,95,96,120};
    int size=sizeof(arr)/sizeof(arr[0]);//数组的长度
    int x,middle;
    scanf("%d",&x);//输入要查找的数
    int left=0;
    int right=size;
    while(left<=right)//循环条件
    {
        middle=(left+right)/2;//中间数
        if(arr[middle]<x)
        {
            left=middle+1;//要查找的数在中间数的右边,左端加一即向右移,缩小范围
        }
        else if(arr[middle]>x)
        {
            right=middle-1;//要查找的数在中间数的左边,右端加一即向左移,缩小范围
        }
        else if(arr[middle]=x)//最后当中间数=要查找的数时查找完毕
        {
            printf("%d在arr[%d]\n位置:第%d个数",x,middle,middle+1);
            break;
        }
    }
    if(left>right)//当left>right时证明此范围内不存在要查找的数
        {
            printf("查无此数\n");
        }
        return 0;
}

 

五.运行结果

c/c++快乐算法第三天

 第十题 数值转换

一.问题描述

c/c++快乐算法第三天

 二.设计思路

c/c++快乐算法第三天

 

三.流程图

c/c++快乐算法第三天

 四.源代码

#include<iostream>
using namespace std;
#define Max 101 //限定数组最大长度
int char_to_num(char ch); //返回字符对应的数字
char num_to_char(int num); //返回数字对应的字符
long source_to_decimal(char temp[],int source);
//返回由原数转换成的十进制数
int decimal_to_object(char temp[],long decimal_num,int object);
//返回转换成目标进制的数组长度
void output(char temp[],int length); //将字符数组逆序输出
int main(){
int source; //存储原来的进制
int object; //存储目标进制
int length; //存储转化后的数组长度
long decimal_num; //存储转换成的十进制数
char temp[Max]; //存储待转化的数值 和转化后的数值
int flag=1; //是否结束程序
while(flag)
{
cout<<"转换前的数是:";
cin>>temp;
cout<<"转换前的进制是:";
cin>>source;
cout<<"转换后的进制是";
cin>>object;
cout<<"转换后的数值是:";
decimal_num=source_to_decimal(temp,source);
length=decimal_to_object(temp,decimal_num,object);
output(temp,length);
cout<<"继续请输入1,否则输入0";
cin>>flag;
}
}
int char_to_num(char ch)
{
if(ch>='0'&&ch<='9')
return ch-'0'; //0~9
else
return ch-'A'+10;//大于10的数字
}
char num_to_char(int num)
{
if(num>=0&&num<=9)
return (char)('0'+num-0);
else
return (char)('A'+num-10);
}
long source_to_decimal(char temp[],int source)
{
long decimal_num=0;
int length;
int i;
for(i=0;temp[i]!='\0';i++);
length=i;
for(i=0;i<length-1;i++)
decimal_num=(decimal_num*source)+char_to_num(temp[i]);
return decimal_num;
}
int decimal_to_object(char temp[],long decimal_num,int object)
{
int i=0;
while(decimal_num)
{
temp[i]=num_to_char(decimal_num%object);
decimal_num=decimal_num/object;
i++;
}
temp[i]='\0';
return i;
}
void output(char temp[],int length)
{
int i;
for(i=length-1;i>=0;i--)
cout<<temp[i];
cout<<endl;
}

 

五.运行结果

c/c++快乐算法第三天

 总结:恭喜你学完第一章趣味算法入门!不知你是在为新赛季的阴间队友而气出内伤,还是在为三千字职业生涯规划结课论文而默默流泪,总之明天就是周一,新的一周就要开始咯,冲哇冲哇!

每日一mo:Opportunity is missed by most people because it is dressed in overalls and looks like work. 

 

原文链接:https://www.cnblogs.com/R-f-12/p/17324542.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:c/c++快乐算法第三天 - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月17日

相关文章

  • Ruby和Ruby on Rails中解析JSON格式数据的实例教程

    Ruby和Ruby on Rails中解析JSON格式数据的实例教程 1. 概述 JSON是一种轻量级的数据交换格式,广泛应用于数据传输和信息交换的场合。 Ruby和Ruby on Rails都提供了强大的JSON解析库,可以快速、简便地对JSON格式数据进行解析和生成。本文将以实例的方式演示在Ruby和Ruby on Rails中解析JSON格式数据的方法…

    C 2023年5月23日
    00
  • Caused by: java.lang.ClassNotFoundException: org.apache.commons.collections.Transformer异常

    框架或应用程序在启动或执行时,可能会抛出各种异常。其中一个常见异常是 java.lang.ClassNotFoundException,这种异常通常表示由类装入器试图加载某个类,但在加载类时未找到相应的类。 当我们的应用程序或框架抛出了 java.lang.ClassNotFoundException: org.apache.commons.collecti…

    C 2023年5月23日
    00
  • C语言之如何求三次方根

    C语言之如何求三次方根 在C语言中,求一个数的三次方根可以使用数学库中的pow()函数,但是这会增加程序的复杂度和开销。另一种方法是通过迭代逐步逼近三次方根的解,这种方法效率高,适合在不使用数学库的情况下求解三次方根。 方案原理 设正数n的三次方根为x,则有: $$ x^3 = n $$ 两边同时取平方根,得到: $$ x^2 = \sqrt{n} $$ 继…

    C 2023年5月23日
    00
  • C语言编程入门必背的示例代码整理大全

    您好,关于“C语言编程入门必背的示例代码整理大全”的完整攻略,以下是详细讲解: 概述 此文档旨在为初学者提供C语言编程入门示例代码整理大全,内容包括语法基础、数组指针、结构体等知识点。示例代码将以最简单易懂的方式呈现,并加入详细注释,以帮助初学者更好地理解和学习。 语法基础 Hello World #include <stdio.h> int m…

    C 2023年5月23日
    00
  • 浅谈c++性能测试工具之计算时间复杂度

    计算时间复杂度的理论基础 在介绍如何使用性能测试工具进行时间复杂度计算之前,我们需要了解一些理论基础。在计算时间复杂度时,我们需要考虑代码执行的次数和输入的规模关系,也就是所谓的时间复杂度公式。 以一个简单的for循环为例,代码如下: for(int i = 0; i < n; i++){ // 一些操作 } 这个for循环中,循环次数与n的大小有关,…

    C 2023年5月23日
    00
  • C语言可变参数列表的用法与深度剖析

    C语言可变参数列表的用法与深度剖析 C语言中的可变参数列表是一种强大的功能,它允许我们定义一个参数数量不定的函数。一般情况下,我们使用可变参数列表来编写那些需要处理不定数量参数的函数,例如printf函数和scanf函数。在本篇文章中,我们将对C语言可变参数列表的用法进行详细讲解,并给出两个示例说明。 什么是可变参数列表? 可变参数列表是指函数的参数数量是不…

    C 2023年5月23日
    00
  • 详解json string转换为java bean及实例代码

    下面是“详解json string转换为java bean及实例代码”的完整攻略: 什么是JSON JSON是一种轻量级的数据交换格式,具有易读易写、占用带宽小、易解析和支持多种语言等优点。在Web开发中,常用于数据传输和Web API。 JSON to Java Bean 转换 在Java中,我们可以通过JSON的转换将JSON字符串转换成Java Bea…

    C 2023年5月23日
    00
  • C语言中基础小问题详细介绍

    C语言中基础小问题详细介绍攻略 在学习C语言的过程中,会遇到一些基础小问题,这些问题虽然看起来不起眼,但它们却是我们在开发过程中需要深入理解和运用的知识点。下面我们将介绍几个基础小问题及其解决方法,希望对您的学习有所帮助。 问题一:如何输出带有引号的字符串? 在C语言中,若要输出带有引号的字符串,可以采用转义字符\。 例如,要输出”hello world”,…

    C 2023年5月23日
    00
合作推广
合作推广
分享本页
返回顶部