算法訓練 字符串比較

資源限制
時間限制:1.0s   內存限制:256.0MB
問題描述
  strncmp函數的原型爲:int strncmp(char *s, char *t, int n);,其功能是比較字符串s和t的前n個字符。若是s<t,返回-1;若是s=t,返回0;若是s>t,返回1。請本身編程實現該函數,並編寫一個程序來測試其正確性。
  輸入格式:輸入有三行,第一行爲字符串s,第二行爲字符串t,第三行爲整數n。
  輸出格式:輸出只有一個整數,即比較結果。
輸入輸出樣例
樣例輸入
world
word
4
樣例輸出
1
 

ASCII可顯示字符

二進制 十進制 十六進制 圖形
0010 0000 32 20 (空格)(␠)
0010 0001 33 21 !
0010 0010 34 22 "
0010 0011 35 23 #
0010 0100 36 24 $
0010 0101 37 25  %
0010 0110 38 26 &
0010 0111 39 27 '
0010 1000 40 28 (
0010 1001 41 29 )
0010 1010 42 2A *
0010 1011 43 2B +
0010 1100 44 2C ,
0010 1101 45 2D -
0010 1110 46 2E .
0010 1111 47 2F /
0011 0000 48 30 0
0011 0001 49 31 1
0011 0010 50 32 2
0011 0011 51 33 3
0011 0100 52 34 4
0011 0101 53 35 5
0011 0110 54 36 6
0011 0111 55 37 7
0011 1000 56 38 8
0011 1001 57 39 9
0011 1010 58 3A :
0011 1011 59 3B ;
0011 1100 60 3C <
0011 1101 61 3D =
0011 1110 62 3E >
0011 1111 63 3F ?

 

 

 

 

 

 

 

 

 

 

 

二進制 十進制 十六進制 圖形
0100 0000 64 40 @
0100 0001 65 41 A
0100 0010 66 42 B
0100 0011 67 43 C
0100 0100 68 44 D
0100 0101 69 45 E
0100 0110 70 46 F
0100 0111 71 47 G
0100 1000 72 48 H
0100 1001 73 49 I
0100 1010 74 4A J
0100 1011 75 4B K
0100 1100 76 4C L
0100 1101 77 4D M
0100 1110 78 4E N
0100 1111 79 4F O
0101 0000 80 50 P
0101 0001 81 51 Q
0101 0010 82 52 R
0101 0011 83 53 S
0101 0100 84 54 T
0101 0101 85 55 U
0101 0110 86 56 V
0101 0111 87 57 W
0101 1000 88 58 X
0101 1001 89 59 Y
0101 1010 90 5A Z
0101 1011 91 5B [
0101 1100 92 5C \
0101 1101 93 5D ]
0101 1110 94 5E ^
0101 1111 95 5F _
 
二進制 十進制 十六進制 圖形
0110 0000 96 60 `
0110 0001 97 61 a
0110 0010 98 62 b
0110 0011 99 63 c
0110 0100 100 64 d
0110 0101 101 65 e
0110 0110 102 66 f
0110 0111 103 67 g
0110 1000 104 68 h
0110 1001 105 69 i
0110 1010 106 6A j
0110 1011 107 6B k
0110 1100 108 6C l
0110 1101 109 6D m
0110 1110 110 6E n
0110 1111 111 6F o
0111 0000 112 70 p
0111 0001 113 71 q
0111 0010 114 72 r
0111 0011 115 73 s
0111 0100 116 74 t
0111 0101 117 75 u
0111 0110 118 76 v
0111 0111 119 77 w
0111 1000 120 78 x
0111 1001 121 79 y
0111 1010 122 7A z
0111 1011 123 7B {
0111 1100 124 7C |
0111 1101 125 7D }
0111 1110 126 7E ~
 
這道題注意格式間的轉化、、
 1 #include<iostream>
 2 #include<string>
 3 //author:QIANG
 4 using namespace std;
 5 int main(){
 6     string s1,s2;
 7     cin>>s1>>s2;
 8     int n,n1,n2;
 9     char c1,c2;
10     cin>>n;
11     int i;
12     for(i=0;i<n;i++){
13         c1=s1[i];
14         c2=s2[i];
15         n1=c1-'A';
16         n2=c2-'A';
17         if(n1>n2){
18             cout<<1;
19             break;
20         }
21         if(n1<n2){
22             cout<<-1;
23             break;
24         }
25     }
26     if(i>=n){
27         cout<<0;
28     }
29     return 0;
30 }
相關文章
相關標籤/搜索