c/c++快樂演算法第三天

来源:https://www.cnblogs.com/R-f-12/archive/2023/04/17/17324542.html
-Advertisement-
Play Games

c/c++感受演算法快樂(3) 開始時間2023-04-16 22:21:10 結束時間2023-04-17 00:09:34 前言:很好,這周就要結束了,大家都回學校了麽,嘻嘻。回顧一下昨天的演算法題,1.4抓交通肇事犯運用枚舉模擬,1.5兔子產子問題運用迭代迴圈,1.6牛頓迭代法求方程根迭代迴圈,1 ...


c/c++感受演算法快樂(3)

開始時間2023-04-16 22:21:10

結束時間2023-04-17 00:09:34

前言:很好,這周就要結束了,大家都回學校了麽,嘻嘻。回顧一下昨天的演算法題,1.4抓交通肇事犯運用枚舉模擬,1.5兔子產子問題運用迭代迴圈,1.6牛頓迭代法求方程根迭代迴圈,1.7最佳存款問題迭代迴圈。什麼是迭代?對電腦特定程式中需要反覆執行的子程式(一組指令),進行一次重覆,即重覆執行程式中的迴圈,直到滿足某條件為止,亦稱為迭代。快來看看今天的問題叭!

第一章 趣味演算法入門

第八題 冒泡排序

一.問題描述

 二.設計思路

  有輸入,並且為自行輸入的n個整數序列。這裡我們需要用到冒泡排序,冒泡排序是什麼?它重覆地走訪過要排序的元素列,依次比較兩個相鄰的元素,如果他們的順序(如從大到小、首字母從A到Z)錯誤就把他們交換過來。走訪元素的工作是重覆地進行直到沒有相鄰元素需要交換,也就是說該元素已經排序完成,如同汽水中的氣泡最終會冒到頂部一樣顧名冒泡排序。冒泡排序總的平均時間複雜度為,冒泡排序是一種穩定排序演算法。升序排列為數據從小到大排列。

 三.流程圖

 四.源代碼

#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;
}

 

五.運行結果

 第九題 折半查找

一.問題描述

 二.設計思路

  

三.流程圖

 四.源代碼

#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;
}

 

五.運行結果

 第十題 數值轉換

一.問題描述

 二.設計思路

 

三.流程圖

 四.源代碼

#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;
}

 

五.運行結果

 總結:恭喜你學完第一章趣味演算法入門!不知你是在為新賽季的陰間隊友而氣出內傷,還是在為三千字職業生涯規劃結課論文而默默流淚,總之明天就是周一,新的一周就要開始咯,沖哇沖哇!

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

 
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 包 CommunityToolkit.Mvvm (又名 MVVM 工具包,以前名為 Microsoft.Toolkit.Mvvm) 是一個現代、快速且模塊化的 MVVM 庫。 它是 .NET 社區工具包的一部分,圍繞以下原則構建: 平臺和運行時獨立 - .NET Standard 2.0、 .NET ...
  • 作者:盧文雙 資深資料庫內核研發 去年年底通過微信公眾號【資料庫內核】設定了一個目標——2023 年要寫一系列 特性介紹+內核解析 的文章(現階段還是以 MySQL 為主)。 雖然關註者很少,但本著“說到就要做到”的原則,從這篇就開始了。 序言: 以前對 MySQL 測試框架 MTR 的使用,主要集 ...
  • Redis命令 1.Redis數據結構介紹 Redis是一個key-value的資料庫,key一般是String類型,value的類型多種多樣,value常見的八種類型: Redis支持五種基本的數據類型:string(字元串),hash(哈希),list(列表),set(集合)及zset(sort ...
  • 影響MySQL查詢性能的因素有很多,我們經常會對查詢語句、索引欄位做一些優化,而其實在表設計的階段就可能產生一些問題。對於表設計,可以對錶結構進行優化,也可以對錶欄位進行優化。以下通過一個具體的案例演示一些常用的表設計優化的方法。 一、業務需求 這裡,就以學生-教師-課程業務作為示例。資料庫需要存放 ...
  • 通過ESLint 檢測 JS/TS 代碼、Prettier 格式化代碼、Stylelint 檢測 CSS/SCSS 代碼和配置 EditorConfig 來實現前端代碼規範約束和統一。 ...
  • “我苦心鍛煉了三年,我變禿了,也變強了。” —— 琦玉老師 0x00 大綱 0x01 前言 四個月前,我在《你是來找茬的吧?對自己的博客進行調優》一文中探討了以博客的使用者而不是開發者身份去進行優化,究竟能做到何種程度的問題。當時以 Edge 瀏覽器的開發者工具里的 lighthouse 評分和載入 ...
  • 並不是所有的場景都適合微服務,我理解技術開發者都有一顆追求新技術的心,但是更重要的是業務場景及團隊。 關於微服務 微服務架構,說白了就是一種上層體系的演變。從最早的單體架構,到前後分離,SOA,甚至微服務架構,其實它們都在做一件事,並且都朝著一個方向去發展:那就是分而治之!從簡! 分而治之有什麼好處 ...
  • 該數據結構需要 Redis 5.0.0 + 版本才可用使用 概述 Redis stream 是 Redis 5 引入的一種新的數據結構,它是一個高性能、高可靠性的消息隊列,主要用於非同步消息處理和流式數據處理。在此之前,想要使用 Redis 實現消息隊列,通常可以使用例如:列表,有序集合、發佈與訂閱 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...