日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

实验7-3-6 字符串转换成十进制整数 (15分)

發(fā)布時(shí)間:2023/12/15 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 实验7-3-6 字符串转换成十进制整数 (15分) 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
十六進(jìn)制字符包括0~9 和 a~f(在本道題中規(guī)定不分大小寫(xiě))

解題思路

  • 循環(huán)輸入一字符串,當(dāng)出現(xiàn)‘#’時(shí)退出輸入。
  • 設(shè)置兩個(gè)標(biāo)志位,分別記錄第一個(gè)負(fù)號(hào)出現(xiàn)的位置和第一個(gè)十六進(jìn)制出現(xiàn)的位置。(如果第一個(gè)十六進(jìn)制字符之前出現(xiàn)大于一個(gè)“-”,同樣按照一個(gè)處理,當(dāng)作負(fù)數(shù))
  • 比較兩個(gè)位置的大小,判斷結(jié)果是否為負(fù)數(shù)。
  • 輸出結(jié)果
  • #include<stdio.h> #define N 1000 //思路:設(shè)置兩個(gè)標(biāo)志位,分別記錄第一個(gè)負(fù)號(hào)出現(xiàn)的位置和第一個(gè)十六進(jìn)制出現(xiàn)的位置(用于判斷正負(fù)) // 比較兩個(gè)位置的大小,判斷結(jié)果是否為負(fù)數(shù)。 // 十六進(jìn)制換算成十進(jìn)制,設(shè)置一個(gè)變量temp=1,然后更新temp *= 16,得到相應(yīng)的結(jié)果。 int main() {char ch;int len1=0,len2=0;char str1[N];//輸入的所有字符串char str2[N];//篩選出所有的十六進(jìn)制字符存儲(chǔ)int str3[N];//把str2字符數(shù)組中的數(shù)字字符轉(zhuǎn)化成數(shù)字int index1,index2;int cnt1=0;int temp=1;int sum=0; //將輸入的字符傳入str1ch=getchar();for(int i=0;ch!='\n';i++){str1[i]=ch;len1++;//輸入的字符串的長(zhǎng)度ch=getchar();}//遍歷尋找第一個(gè)負(fù)號(hào)“-”的位置for(int j=0;j<len1;j++){if(str1[j]=='-'){index1=j;break;}}//遍歷尋找第一個(gè)十六進(jìn)制數(shù)的位置for(int k=0;k<len1;k++){if((str1[k]>='0'&&str1[k]<='9')||(str1[k]>='a'&&str1[k]<='f')||(str1[k]>='A'&&str1[k]<='F')){index2=k;break;}}//遍歷篩選將所有十六進(jìn)制字符存入字符數(shù)組str2for(int k=0;k<len1;k++){if((str1[k]>='0'&&str1[k]<='9')||(str1[k]>='a'&&str1[k]<='f')||(str1[k]>='A'&&str1[k]<='F')){str2[cnt1++]=str1[k];}}//將所有十六進(jìn)制數(shù)轉(zhuǎn)換成數(shù)字for(int i=0;i<cnt1;i++){if(str2[i]>='0'&&str2[i]<='9'){str3[i]=str2[i]-'0';}else if(str2[i]>='a'&&str2[i]<='f'){str3[i]=str2[i]-'a'+10;}else if(str2[i]>='A'&&str2[i]<='F'){str3[i]=str2[i]-'A'+10;}}//將str3字符數(shù)組中所有十六進(jìn)制數(shù)全部轉(zhuǎn)換為十進(jìn)制//從個(gè)位往高位走for(int j=cnt1-1;j>=0;j--){sum+=temp*str3[j];temp*=16;}//輸出if(index1<index2){printf("-%d\n",sum);}else if(index1>index2){printf("%d\n",sum);}return 0; }

    總結(jié)

    以上是生活随笔為你收集整理的实验7-3-6 字符串转换成十进制整数 (15分)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。