国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

C語言:選擇+編程(每日一練Day5)

這篇具有很好參考價值的文章主要介紹了C語言:選擇+編程(每日一練Day5)。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

C語言:選擇+編程(每日一練Day5),C語言練習(xí),c語言,算法,數(shù)據(jù)結(jié)構(gòu),學(xué)習(xí),深度學(xué)習(xí),筆記,c++

目錄

選擇題:

題一:

題二:

題三:

題四:

題五:

編程題:

題一:數(shù)字在升序數(shù)組中出現(xiàn)的次數(shù)

思路一:

思路二:

題二:整數(shù)轉(zhuǎn)換?

思路一:

本人實力有限可能對一些地方解釋和理解的不夠清晰,可以自己嘗試讀代碼,或者評論區(qū)指出錯誤,望海涵!

感謝大佬們的一鍵三連!?感謝大佬們的一鍵三連!?感謝大佬們的一鍵三連!


選擇題:

題一:

1、如下程序的功能是( )
#include <stdio.h>
int main()
{
????????char ch[80] = "123abcdEFG*&";
????????int j;
????????puts(ch);
????????for(j = 0; ch[j] != '\0'; j++)
????????if(ch[j] >= 'A' && ch[j] <= 'Z')
????????ch[j] = ch[j] + 'e' - 'E';
????????puts(ch);
????????return 0;
}

A: 測字符數(shù)組ch的長度
B: 將數(shù)字字符串ch轉(zhuǎn)換成十進制數(shù)
C: 將字符數(shù)組ch中的小寫字母轉(zhuǎn)換成大寫

D: 將字符數(shù)組ch中的大寫字母轉(zhuǎn)換成小寫

答案解析:

????????一個字母對應(yīng)的大寫和小寫之間的ASCII碼值相差32,而且小寫的大于大寫的。所以題中'e'和'E'之間的ASCII碼值相差32(ch[j]+'e'-'E'相當(dāng)于ch[j]+32)。一個字母從大寫轉(zhuǎn)化為小寫就是在它自身上+32,小寫轉(zhuǎn)大寫則是-32。

題二:

2、對于代碼段,下面描述正確的是( )
t=0;
while(printf("*"))
{
????????t++;
????????if (t<3)
????????break;
}

A:其中循環(huán)控制表達式與0等價? ? ? ? ?B:其中循環(huán)控制表達式與'等價
C:其中循環(huán)控制表達式是不合法的? ??D:以上說法都不對

答案解析:

????????因print(“*”)函數(shù)調(diào)用的返回值是字符串中字符的個數(shù),即為1。所以while后面的條件恒為真,所以循環(huán)控制表達式與'0'是等價的(字符'0'不是0)。

題三:

3、以下程序運行時,若輸入1abcedf2df<回車> 輸出結(jié)果是( )

#include <stdio.h>
int main()
{
????????char ch;
????????while ((ch = getchar()) != '\n')
????????{
????????????????if (ch % 2 != 0 && (ch >= 'a' && ch <= 'z'))
????????????????ch = ch - 'a' + 'A';
????????????????putchar(ch);
????????}
????????printf("\n");
????????return 0;
}

A: 1abcedf2df? ? ? ? B: 1ABCEDF2DF

C: 1AbCEdf2df? ? ?D: 1aBceDF2DF

答案解析:

????????程序首先考慮ch的ASCII碼值是不是奇數(shù),再看是不是小寫字母,同時滿足時被改為大寫字母。

題四:

4、下列條件語句中,功能與其他語句不同的是( )
A: if(a) printf("%d\n",x); else printf("%d\n",y);
B: if(a==0) printf("%d\n",y); else printf("%d\n",x);
C: if (a!=0) printf("%d\n",x); else printf("%d\n",y);

D: if(a==0) printf("%d\n",x); else printf("%d\n",y);

答案解析:

????????D選項與眾不同,其他都是a==0時輸出y,a!=0時輸出x。

題五:

5、我們知道C語言的 break 語句只能跳出離它最近的一層循環(huán),可是有時候我們需要跳出多層循環(huán),下列跳出多層循環(huán)的做法正確的是【多選】( )
A: 將程序?qū)懗珊瘮?shù)用return結(jié)束函數(shù),便可跳出循環(huán);
B: 修改外層循環(huán)條件例如:

for( int i = 0 ; i < MAX1 ; i ++ )
{
    for( int j = 0 ; j < MAX2 ; j ++ )
    {
        if( condition )
    {
    i = MAX1;
    break;
}  


C: 在外層循環(huán)設(shè)置判斷條件例如:

for( ; symbol != 1 && condition2 ; )
{
    for( ; symbol != 1 && condition3 ; )
    {
        if( condition1 )
        symbol = 1 ;
    }
}


D: 在外層循環(huán)后面加入break例如:

for( ; condition2 ; )
{
    for( ; condition3 ; )
    {
        if( condition1 )
        symbol = 1 ;
    } 
    if(symbol == 1 )
    break ;
}

答案解析:

????????此題旨在整理跳出多層循環(huán)的方法,每個選項都是正確的,代碼為偽代碼,condition代表邏輯表達式。

編程題:

題一:數(shù)字在升序數(shù)組中出現(xiàn)的次數(shù)

數(shù)字在升序數(shù)組中出現(xiàn)的次數(shù)_??皖}霸_牛客網(wǎng) (nowcoder.com)

C語言:選擇+編程(每日一練Day5),C語言練習(xí),c語言,算法,數(shù)據(jù)結(jié)構(gòu),學(xué)習(xí),深度學(xué)習(xí),筆記,c++

示例1

輸入:

[1,2,3,3,3,3,4,5] , 3

復(fù)制返回值:

4

思路一:

? ? ? ? 二分查找法:

????????最直接的辦法就是:二分查找一個比目標(biāo)數(shù)小一位的數(shù),由于這里是整型,所以我們直接給k+任意小數(shù)就能實現(xiàn)找的目標(biāo)數(shù)的上界或下界,此時相減就是目標(biāo)數(shù)的個數(shù)。

 //函數(shù)實現(xiàn)二分查找
int community(int* nums,int numsLen,double k)
{
    int left = 0;
    int right = numsLen-1;
    while(left <= right)
    {
        int mid = (left+right)/2;
        if(nums[mid] > k)
        {
            right = mid-1;
        }
        else if(nums[mid] < k)
        {
            left = mid+1;
        }
    }
    return left;
}

int GetNumberOfK(int* nums, int numsLen, int k )
{
    //查找到下界下標(biāo)
    int a1 = community(nums,numsLen,k+0.5);
    //查找到上界下標(biāo)
    int a2 = community(nums,numsLen,k-0.5);
    return a1-a2;
}

思路二:

????????采用遍歷也能搞定,不過數(shù)組為非降序,采用二分查找的思想最優(yōu),先二分找到最左邊的數(shù)字位置,再二分查找最右邊的數(shù)字位置,兩個位置相減+1就是長度了。
中間比找的值大:則要找的數(shù)字肯定在左邊,right = mid - 1;
中間比找的值小:則要找的數(shù)字肯定在右邊, left = mid + 1;

中間值與找的值相同:
找的最左邊數(shù)字:如果mid就是left,則返回mid就行,否則重置right=mid-1,把中心不斷向左偏移
找的最右邊數(shù)字:如果mid就是right,則返回mid就行,否則重置left=mid+1,把中心不斷向右偏移。

int get_last_or_first_idx(int* data, int len, int k, int flag) 
{	
	//flag:0-找左邊, 1-找右邊
	int left = 0, right = len - 1, mid;
	while (left <= right) 
	{
		mid = left + (right - left) / 2;
		if (data[mid] > k)
			right = mid - 1;
		else if (data[mid] < k)
			left = mid + 1;
		else 
		{
			if (flag == 0) 
			{	
				//flag==0時,找最左邊的數(shù)字
				if (mid == left || data[mid - 1] != k) 
					return mid;
				else 
					//把中心向左推
					right = mid - 1;
			}
			else 
			{
				//flag==1時,找最右邊的數(shù)字
				if (mid == right || data[mid + 1] != k) 
					return mid;
				else 
					//把中心向右推
					left = mid + 1;
			}
		}
	} 
	return - 1;
} 
int GetNumberOfK(int* data, int dataLen, int k) 
{
	if (dataLen == 0) 
		return 0;
	int left = get_last_or_first_idx(data, dataLen, k, 0);
	int right = get_last_or_first_idx(data, dataLen, k, 1);
	if (left == -1 && right == -1) 
		return 0; //表示沒有找到k這個數(shù)據(jù)
	return right - left + 1;
}

題二:整數(shù)轉(zhuǎn)換?

面試題 05.06. 整數(shù)轉(zhuǎn)換 - 力扣(LeetCode)

C語言:選擇+編程(每日一練Day5),C語言練習(xí),c語言,算法,數(shù)據(jù)結(jié)構(gòu),學(xué)習(xí),深度學(xué)習(xí),筆記,c++

思路一:

解題必懂的操作符:

????????按位異或“ ^ ”:?二進制位相同為“ 0 ”,不相同為“ 1 ”;

????????比如我們的數(shù)字1,二進制表示為 0001,數(shù)字2,二進制表示為 0010,對1和2進行異或,結(jié)果為 0011。

????????按位“ & ”:二進制位兩個都是“ 1 ”為“ 1 ”,其余都是“ 0 ”;

? ? ? ? 右移“ >> ”:二進制位向右移動。

? ? ? ? ?首先需要先把兩數(shù)異或,把值存在變量 c 中,然后再用到我們的按位與運算符,這里我們利用數(shù)字1,因為它的二進制中只有1個“ 1 ”,且在最右邊,我們可以把它們進行比較。 因為1只有最右邊為1,如果想32位都能比到的話,就需要我們的右移操作符,每次比較變量 c 就向右移動“ i ”位(左端補符號位),此時只需要在外面套上for循環(huán),循環(huán)次數(shù)為32次,這樣我們就能把 c 中的每一位與數(shù)字1進行按位與比較。 所以在 c 的二進制位中找到一個“ 1 ”,count++,最后程序返回count的值就行了。

int convertInteger(int A, int B)
{
    //按位異或后得到的二進制里的1的個數(shù)就是需要改變的個數(shù)
    int c = A^B;
    //記錄需要改變的個數(shù)
    int count = 0;
    //遍歷二進制
    for(int i = 0;i < 32;i++)
    {
        //每次向右移動i位
        if(((c >> i) & 1) == 1)
        {
            count++;
        }
    }
    return count;
}

本人實力有限可能對一些地方解釋和理解的不夠清晰,可以自己嘗試讀代碼,或者評論區(qū)指出錯誤,望海涵!

感謝大佬們的一鍵三連!?感謝大佬們的一鍵三連!?感謝大佬們的一鍵三連!

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??C語言:選擇+編程(每日一練Day5),C語言練習(xí),c語言,算法,數(shù)據(jù)結(jié)構(gòu),學(xué)習(xí),深度學(xué)習(xí),筆記,c++文章來源地址http://www.zghlxwxcb.cn/news/detail-708186.html

到了這里,關(guān)于C語言:選擇+編程(每日一練Day5)的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • C語言:選擇+編程(每日一練Day13)

    C語言:選擇+編程(每日一練Day13)

    目錄 選擇題: 題一: 題二: 題三: 題四: 題五: 編程題: 題一:統(tǒng)計每個月兔子的總數(shù) 思路一: 題二:數(shù)列的和 思路一: 本人實力有限可能對一些地方解釋和理解的不夠清晰,可以自己嘗試讀代碼,或者評論區(qū)指出錯誤,望海涵! 感謝大佬們的一鍵三連!?感謝大佬

    2024年02月08日
    瀏覽(23)
  • C語言:選擇+編程(每日一練Day11)

    C語言:選擇+編程(每日一練Day11)

    目錄 選擇題: 題一: 題二: 題三: 題四: 題五: 編程題: 題一:最大連續(xù)1的個數(shù) 思路一: 題二:完全數(shù)計算? 思路二: 本人實力有限可能對一些地方解釋和理解的不夠清晰,可以自己嘗試讀代碼,或者評論區(qū)指出錯誤,望海涵! 感謝大佬們的一鍵三連!?感謝大佬們

    2024年02月09日
    瀏覽(15)
  • C語言:選擇+編程(每日一練Day4)

    C語言:選擇+編程(每日一練Day4)

    1、 設(shè)變量已正確定義,以下不能統(tǒng)計出一行中輸入字符個數(shù)( 不包含回車符 )的程序段是( ) A: n=0;while(ch=getchar()!=\\\'n\\\')n++;? ? ?B: n=0;while(getchar()!=\\\'n\\\')n++; C: for(n=0;getchar()!=\\\'n\\\';n++);? ? ? ? ? ? ? D: n=0;for(ch=getchar();ch!=\\\'n\\\';n++); 答案解析:? ? ?? ????????對于for循環(huán),其

    2024年02月09日
    瀏覽(18)
  • C語言:選擇+編程(每日一練Day6)

    C語言:選擇+編程(每日一練Day6)

    目錄 ?編輯選擇題:? 題一: 題二: 題三: 題四: 題五: 編程題: 題一:至少是其他數(shù)字兩倍的最大數(shù) 思路一: 思路二: 題二:兩個數(shù)組的交集 ?思路一: 本人實力有限可能對一些地方解釋和理解的不夠清晰,可以自己嘗試讀代碼,或者評論區(qū)指出錯誤,望海涵! 感

    2024年02月11日
    瀏覽(20)
  • C語言:選擇+編程(每日一練Day7)

    C語言:選擇+編程(每日一練Day7)

    目錄 選擇題: 題一: 題二: 題三: 題四: 題五: 編程題: 題一:圖片整理 思路一: 思路二:? 題二:尋找數(shù)組的中心下標(biāo)? 思路一: 本人實力有限可能對一些地方解釋和理解的不夠清晰,可以自己嘗試讀代碼,或者評論區(qū)指出錯誤,望海涵! 感謝大佬們的一鍵三連!

    2024年02月11日
    瀏覽(18)
  • C語言:選擇+編程(每日一練Day3)

    C語言:選擇+編程(每日一練Day3)

    目錄 選擇題: 題一: 題二: 題三: 題四: 題五: 編程題: 題一:記負均正 思路一: 題二:旋轉(zhuǎn)數(shù)組的最小數(shù)字 思路一: 1、已知函數(shù)的原型是: int fun(char b[10], int *a); ,設(shè)定義: char c[10];int d; , 正確的調(diào)用語句是 ( ) A: fun(c,d);? ?? B: fun(c,d);? ? C: fun(c,d);? ? D: f

    2024年02月09日
    瀏覽(21)
  • C語言:選擇+編程(每日一練Day8)

    C語言:選擇+編程(每日一練Day8)

    目錄 選擇題:? 題一: 題二: 題三: 題四: 題五: 編程題: 題一:字符個數(shù)統(tǒng)計 思路一: 題二:多數(shù)元素 思路一:? 本人實力有限可能對一些地方解釋和理解的不夠清晰,可以自己嘗試讀代碼,或者評論區(qū)指出錯誤,望海涵! 感謝大佬們的一鍵三連!?感謝大佬們的一

    2024年02月11日
    瀏覽(21)
  • C語言:選擇+編程(每日一練Day9)

    C語言:選擇+編程(每日一練Day9)

    目錄 選擇題: 題一: 題二: 題三: 題四: 題五: 編程題: 題一:自除數(shù) 思路一: 題二:除自身以外數(shù)組的乘積 思路二: 本人實力有限可能對一些地方解釋和理解的不夠清晰,可以自己嘗試讀代碼,或者評論區(qū)指出錯誤,望海涵! 感謝大佬們的一鍵三連!?感謝大佬們

    2024年02月09日
    瀏覽(22)
  • C語言:選擇+編程(每日一練Day1)

    C語言:選擇+編程(每日一練Day1)

    目錄 ?選擇題: 題一: 題二: 題三:? 題四:? 題五: 編程題: 題一:打印1到最大的n位數(shù) 示例1 思路一: 題二:計算日期到天數(shù)轉(zhuǎn)換 示例1 ?思路一: 本人實力有限可能對一些地方解釋和理解的不夠清晰,可以自己嘗試讀代碼,或者評論區(qū)指出錯誤,望海涵! 1、執(zhí)行下

    2024年02月09日
    瀏覽(25)
  • C語言:每日一練(選擇+編程)

    C語言:每日一練(選擇+編程)

    目錄 ?選擇題: 題一: 題二: 題三:? 題四:? 題五: 編程題: 題一:打印1到最大的n位數(shù) 示例1 思路一: 題二:計算日期到天數(shù)轉(zhuǎn)換 示例1 ?思路一: 本人實力有限可能對一些地方解釋和理解的不夠清晰,可以自己嘗試讀代碼,或者評論區(qū)指出錯誤,望海涵! 1、執(zhí)行下

    2024年02月12日
    瀏覽(16)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包