大一作業習題

第一題:答案:

#include <stdio.h> 
void sort(int a[], int m)  //將數組a的前m個元素(從小到大)排序 
{int i = 0;for (i = 0; i < m - 1; i++){int j = 0;int flag = 1;for (j = 0; j < m - 1 - i; j++){if (a[j] > a[j + 1]){int t = 0;t = a[j];a[j] = a[j + 1];a[j + 1] = t;flag = 0;}}if (flag == 1){break;}}
}
void input(int a[], int m) //依次從鍵盤輸入數組a的前m個元素 
{int i = 0;for (i = 0; i < m; i++){scanf("%d", &a[i]);}
}
void print(int a[], int m) //依次輸出數組a的前m個元素 
{int i = 0;for (i = 0; i < m; i++){printf("%4d", a[i]);}printf("\n");
}
void insertSortedList(int a[], int m, int num) //將num插入到數組a中(數組a的前m個元素已經排序),使得數組a仍然升序。
{a[m] = num;int i = 0;for(i=m;i>=0;i--){if (a[i] < a[i-1]){int t = a[i-1];a[i-1] = a[i];a[i] = t;}else{break;}}
}
void main()
{int m, k;scanf("%d", &m);int alist[1000];input(alist, m);sort(alist, m);print(alist, m);scanf("%d", &k);insertSortedList(alist, m, k);print(alist, m + 1);
}

第二題:

答案:

#include <stdio.h>
int gcd(int a, int b); //計算并返回整數a,整數b的最大公約數. 
void add(int op1[], int op2[], int rst[]); //計算分數op1和op2的和,保存結果到rst. 
void sub(int op1[], int op2[], int rst[]); //計算分數op1和op2的差,保存結果到rst.
void mul(int op1[], int op2[], int rst[]); //計算分數op1和op2的積,保存結果到rst.
void div(int op1[], int op2[], int rst[]); //計算分數op1和op2的商,保存結果到rst.void main()
{int a, b, c, d;int op1[2], op2[2], rst[2];scanf("%d%d", &op1[1], &op1[0]);scanf("%d%d", &op2[1], &op2[0]);add(op1, op2, rst);printf("%d/%d + %d/%d = %d/%d\n", op1[1], op1[0], op2[1], op2[0], rst[1], rst[0]);sub(op1, op2, rst);printf("%d/%d - %d/%d = %d/%d\n", op1[1], op1[0], op2[1], op2[0], rst[1], rst[0]);mul(op1, op2, rst);printf("%d/%d * %d/%d = %d/%d\n", op1[1], op1[0], op2[1], op2[0], rst[1], rst[0]);div(op1, op2, rst);printf("%d/%d / %d/%d = %d/%d\n", op1[1], op1[0], op2[1], op2[0], rst[1], rst[0]);
}int gcd(int a, int b)//返回參數a,b的最大公約數
{int r = a % b;while (r != 0){a = b;b = r;r = a % b;}return b;
}
void add(int op1[], int op2[], int rst[]) //計算分數op1和op2的和,保存結果到rst. 
{int fm = op1[0] * op2[0];                   //和的分母int fz = op1[1] * op2[0] + op2[1] * op1[0]; //和的分子int g = gcd(fm, fz);rst[0] = fm / g;                     //分子分母同時除以它們的最大公約數,實現約分rst[1] = fz / g;if (rst[0] < 0)                              //確保分母為正數{rst[0] = -rst[0];rst[1] = -rst[1];}
}
void sub(int op1[], int op2[], int rst[])  //計算分數op1和op2的差,保存結果到rst.
{int fm = op1[0] * op2[0];int fz = op1[1] * op2[0] - op2[1] * op1[0];int g = gcd(fm, fz);rst[0] = fm / g;rst[1] = fz / g;if (rst[0] < 0)                              //確保分母為正數{rst[0] = -rst[0];rst[1] = -rst[1];}
}
void mul(int op1[], int op2[], int rst[]) //計算分數op1和op2的積,保存結果到rst.
{int fm = op1[0] * op2[0];int fz = op1[1] * op2[1];int g = gcd(fm, fz);rst[0] = fm / g;rst[1] = fz / g;if (rst[0] < 0)                              //確保分母為正數{rst[0] = -rst[0];rst[1] = -rst[1];}
}
void div(int op1[], int op2[], int rst[])  //計算分數op1和op2的商,保存結果到rst.
{int fm = op1[0] * op2[1];int fz = op1[1] * op2[0];int g = gcd(fm, fz);rst[0] = fm / g;rst[1] = fz / g;if (rst[0] < 0)                              //確保分母為正數{rst[0] = -rst[0];rst[1] = -rst[1];}
}

第三題:

答案:

#include <stdio.h> 
int myisdigital(char ch);                //數字字符判斷函數,如果ch是數字字符,則返回1,否則返回0; 
int myisalpha(char ch);                  //字母字符判斷函數,如果ch是大小寫字母字符, 則返回1,否則返回0; 
int mystrlen(char str[]);                // 返回指定字符串str的長度 (不計\0字符) 
void mystrcat(char str1[], char str2[]);  // 連接的兩個字符串, 將str2連接到str1后面 
int mystrcmp(char str1[], char str2[]);  //比較兩個字符串,如果str1大,則返回1;如果str2則返回-1;如果相等,返回0; 
void mystrcpy(char str1[], char str2[]);  //復制字符串str2到字符串str1中 void main()
{char str1[1000], str2[100], tmp[100]; int m;int num_alpha = 0; //str1中的字母字符的個數 int num = 0;       //str2中的數組字符構成的整數 int i;scanf("%s%s%d", str1, str2, &m);printf("%d,", mystrlen(str1) + mystrlen(str2));for (i = 0; i < mystrlen(str1); i++)if (myisalpha(str1[i]))num_alpha++;for (i = 0; i < mystrlen(str2); i++)if (myisdigital(str2[i]))num = num * 10 + str2[i] - '0'; //找到一個新數符,將原來的數字左移一位,然后在末位添加新數符 printf("%d,%d,", num_alpha, num);if (mystrcmp(str1, str2) > 0)  // str1比較大,則交換 {mystrcpy(tmp, str1);mystrcpy(str1, str2);mystrcpy(str2, tmp);}for (i = 1; i <= m; i++)mystrcat(str1, str2);printf("%s", str1);
}int myisdigital(char ch)
{if (ch >= '0' && ch <= '9')return 1;elsereturn 0;
}void mystrcat(char str1[], char str2[])
{int i = 0, j = 0;while (str1[i] != '\0')i++;while (str2[j] != '\0'){str1[i] = str2[j];i++;j++;}str1[i] = '\0';  //給str1最后賦值一個結束字符,這里不可遺漏!!! 
}int myisalpha(char ch)                  //字母字符判斷函數,如果ch是大小寫字母字符, 則返回1,否則返回0;
{if ((ch >= 'A' && ch <= 'Z') || (ch >= 'a' && ch <= 'z'))return 1;elsereturn 0;
}int mystrlen(char str[])                // 返回指定字符串str的長度 (不計\0字符)
{int i = 0;while (str[i] != '\0'){i++;}return i;
}int mystrcmp(char str1[], char str2[])  //比較兩個字符串,如果str1大,則返回1;如果str2則返回-1;如果相等,返回0;
{int i = 0, j = 0;if (mystrlen(str1) < mystrlen(str2)){for (i = 0; i <= mystrlen(str1); i++){if (str1[i] > str2[i])return 1;if ((str1[i] < str2[i])|| (str1[i] == str2[i]) && i == mystrlen(str1))return -1;}}if (mystrlen(str1) > mystrlen(str2)){for (i = 0; i <= mystrlen(str2); i++){if (str1[i] > str2[i] || ((str1[i] == str2[i]) && i == mystrlen(str2)))return 1;if (str1[i] < str2[i])return -1;}}if (mystrlen(str1) == mystrlen(str2)){for (i = 0; i <= mystrlen(str2); i++){if (str1[i] > str2[i])return 1;if (str1[i] < str2[i])return -1;if ((str1[i] == str2[i]) && i == mystrlen(str2))return 0;}}
}void mystrcpy(char str1[], char str2[])  //復制字符串str2到字符串str1中 
{int i = 0;for (i = 0; i < mystrlen(str2); i++){str1[i] = str2[i];}str1[i] = '\0';
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/214413.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/214413.shtml
英文地址,請注明出處:http://en.pswp.cn/news/214413.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Java八股文面試全套真題【含答案】- Servlet篇

以下是一些關于Servlet的經典面試題以及它們的答案&#xff1a; 什么是 Servlet&#xff1f; 答案&#xff1a;Servlet 是運行在服務器上&#xff0c;用于處理客戶端請求并生成響應的 Java 類。 Servlet 和 JSP 之間的區別是什么&#xff1f; 答案&#xff1a;Servlet 是基于…

1.鴻蒙應用程序開發app_hap開發環境搭建

1.下載Node.js, Javascipts的運行環境 node.js版本下載v12.18.3/https://www.cnblogs.com/txwtech/p/17865780.html 2.下載并安裝DevEco Studio DevEco Studio 3.1 DevEco Studio 3.1配套支持HarmonyOS 3.1版本及以上的應用及服務開發&#xff0c;提供了代碼智能編輯、低代…

Docker筆記:Docker中簡單配置Mysql/Redis/Mongodb容器

Docker 配置 Mysql 容器 1 &#xff09;方案1&#xff1a;基于centos等linux操作系統 啟動centos鏡像&#xff0c;在里面安裝 mysql這樣比較麻煩&#xff0c;配置的東西很多 … 2 &#xff09;方案2&#xff1a;直接用 mysql 鏡像 (推薦) $ docker pull mysql 下載鏡像$ do…

589. N 叉樹的前序遍歷

589. N 叉樹的前序遍歷 java1&#xff1a;stack棧&#xff1a;沒看懂 class Solution {public List<Integer> preorder(Node root) {List<Integer> res new ArrayList<Integer>();if (root null) {return res;}Map<Node, Integer> map new HashMa…

C盤瘦身,C盤清理

以下只是我的C盤清理經驗~ 一.【用軟件簡單清理C盤】 使用一些垃圾清理軟件&#xff0c;簡單的初步把C盤先清理一遍。&#xff08;這種軟件太多我就不推薦了……&#xff09; 二.【WPS清理大師】 因為我電腦裝了WPS&#xff0c;發現右鍵單擊C盤有個選項【釋放C盤空間】&#xf…

接口自動化框架(Pytest+request+Allure)

前言&#xff1a; 接口自動化是指模擬程序接口層面的自動化&#xff0c;由于接口不易變更&#xff0c;維護成本更小&#xff0c;所以深受各大公司的喜愛。 接口自動化包含2個部分&#xff0c;功能性的接口自動化測試和并發接口自動化測試。 本次文章著重介紹第一種&#xff0c…

Vue3.3.4中watch無法監測props的更改

背景 網上說了很多解決方案&#xff0c;都是通過watch(() > props.value, (newValue, oldValue) > {})解決&#xff0c;或者是加上{deep: true}附加屬性。但是我在Vue3.3.4中&#xff0c;還是無法解決。 下面說一下我的解決方案。 解決方案 通過父組件調用子組件defineE…

點云/Mesh 常見處理庫和軟件匯總

注&#xff1a;參考 網址1、網址2 文章目錄 軟件通用點云/Mesh處理庫通用幾何處理庫專用功能庫 軟件 Processing MeshLabCloudCompareTrimeshPyVistaVedo Visualization Simple-3dvizPlotOptiX (Requires CUDA-enabled GPU)PolyscopePyrender 通用點云/Mesh處理庫 PCL &am…

【開發問題】vue的前端和java的后臺,用sm4,實現前臺加密,后臺解密

sm4加密 vue引入的包代碼加密解密 javamaven代碼運行結果 vue 引入的包 npm install sm-crypto代碼加密解密 加密&#xff1a; key &#xff1a;代表著密鑰&#xff0c;必須是16 字節的十六進制密鑰 password &#xff1a;加密前的密碼 sm4Password &#xff1a;代表sm4加密…

Python之格式化保存數據點

功能&#xff1a;將平面點集存儲為格式化txt文檔&#xff0c;每個坐標值為5位整數&#xff0c;前三位為整數&#xff0c;后2位為小數 輸入&#xff1a;平面點坐標&#xff0c;用列表存儲&#xff0c;列表的元素為點坐標元組 輸出&#xff1a;txt文件&#xff0c;每行一個點坐…

【計算機網絡】應用層電子郵件協議

一、電子郵件系統架構 電子郵件是一個典型的異步通信系統&#xff0c;發送方從UA&#xff0c;也就是郵件客戶端&#xff0c;通過應用層SMTP協議&#xff0c;傳輸層tcp協議&#xff0c;發送給發送方的郵件服務器&#xff0c;比如使用的是163郵箱&#xff0c;163提供的SMTP服務器…

python中實現yaml文件管理參數

yaml參數管理器 這是文件目錄關系&#xff0c;其中config存放.yaml文件&#xff0c;scripts存放py文件 然后就可以自由使用了&#xff1a; import yaml import os#獲取路徑 script_directory os.path.dirname(os.path.abspath(__file__)) # 相對于腳本文件的路徑 image_relat…

Swift “黑魔法”之動態獲取類實例隱藏屬性的值

概覽 在 Swift 代碼的調試中,我們時常驚嘆調試器的無所不能:對于大部分“黑盒”類實例的內容,調試器也都能探查的一清二楚。 想要自己在運行時也能輕松找到 Thread 實例“私有”屬性的值嗎(比如 seqNum)? 在本篇博文中您將學到如下內容: 概覽1. 借我,借我,一雙慧眼吧…

字符統計[c]

#include<stdio.h> #include<string.h> int main() {int a,b,c;abc0;char s[100];int i0;while(1){i;scanf("%c",&s[i]);if(s[i]?)break;}for(int k1;k<i;k){if(s[k]>48&&s[k]<57){a;//數字}else if((s[k]>65&&s[k]<…

Altair Radioss碰撞 安全與沖擊 衡祖仿真

Altair Radioss是解決瞬態加載工況下非線性問題的領先的結構分析求解器。其具備高擴展性、高品質、高魯棒性&#xff0c;以及諸多功能&#xff1a;多域求解技術、高級材料功能(復合材料)等。Radioss求解器被廣泛應用于汽車、航空航天、電子/家電、包裝、軌道機車、生物醫療、能…

前端項目有關面試

目錄 [TOC](目錄) 1. MVC、MVP、MVVM2.大文件上傳、多文件上傳和斷點續傳的區別3. 前端存儲4.什么是前端自適應5.瀏覽器原理5.1 從輸入url到看到界面的過程5.2 跨域 1. MVC、MVP、MVVM MVC、MVP、MVVM 是常見的軟件架構設計模式。MVVM&#xff1a;是一種軟件架構設計模式&…

c語言實現鏈表

鏈表是一種常見的數據結構&#xff0c;用于存儲一系列的元素。它由一系列的節點&#xff08;Node&#xff09;組成&#xff0c;每個節點包含數據和指向下一個節點的指針。不同于數組需要連續的內存空間來存儲元素&#xff0c;鏈表使用指針將節點按照某種邏輯順序連接起來。 每…

C 語言入門:如何編寫 Hello World

C 語言簡介 C 語言是由 Dennis Ritchie 于 1972 年在貝爾實驗室創建的一種通用編程語言。盡管年代久遠&#xff0c;它仍然是一款非常流行的語言。它之所以受歡迎的主要原因是它是計算機科學領域的基礎語言之一。C 語言與 UNIX 緊密相連&#xff0c;因為它被用于編寫 UNIX 操作…

Audio Signal (MATLAB) 代碼學習1-常見問題

問題描述 使用MATLAB完成如下操作 加載音頻文件,并存儲到變量x中將x和一個頻率為440Hz的正弦信號相加,用結果定義一個新的信號y繪制y信號的時域圖,并正確定義時間軸利用Hann window(漢寧窗)從y中提取一個20ms的窗信號利用線性預測編碼(階數20)預測白化濾波器的參數。% …

訊飛星火認知大模型與軟件測試結合,提升軟件質量與效率

隨著人工智能技術的不斷發展&#xff0c;越來越多的企業開始將其應用于軟件開發過程中。其中&#xff0c;訊飛星火認知大模型作為一種基于深度學習的自然語言處理技術&#xff0c;已經在語音識別、機器翻譯、智能問答等領域取得了顯著的成果。而在軟件測試領域&#xff0c;訊飛…