C語言 將字符串逆序輸出的實例
將字符串逆序輸出:我先說一個我的錯誤代碼,一開始真的不知道哪里錯了,但是當時的想法是自以為是可以的,大家可以先看看我的錯誤代碼
這個代碼是錯誤的,正確的在最下方,不要急,我只是展示一下自己的錯誤,哈哈
#include <stdio.h>
#include <iostream>
#include <string.h>
#include <math.h>
using namespace std;
void reverse(char a[])
{
char *p=a,*q=a,c;
int i;
while(*p!='\0')
p++;
p--;//此刻p指向最后一個元素
// while(p>q)
// {
// c=*p;
// *p=*q;
// *q=c;
// p--;
// q++;
// }
i=0;
for(i=0; p>=q; i++)
{
a[i]=*(p);//代碼就是這里出的錯,在下面解釋一下
printf("*(p)==%c a[%d]==%c\n",*(p),i,a[i]);
p--;
}
}
int main()
{
char a[100];
scanf("%s",a);
reverse(a);
printf("%s",a);
return 0;
}
上面代碼:我一開始想著,定義一個指針p,然后先將指針指向最后一個元素,然后慢慢往回(前面)指,再將指針p指向的值賦給a[i],i從0開始變化,這個想法其實沒有錯,但是卻忽略了,指針只有改變地址的權(quán)利,而賦值則是將字符串完全改變了,那么指針一開始指向中間靠后的值的時候,原來a字符串里面中間靠前的字符就會改變(因為是逆著賦值的),那么到了指針p指向中間靠前的時候,p指的是已經(jīng)變化過的a中的字符值啦。
那么問題來了,怎樣做呢,將對稱位置的字符交換即可。
下面是正確代碼,比較簡單,不做過多介紹啦
#include <stdio.h>
#include <iostream>
#include <string.h>
#include <math.h>
using namespace std;
void reverse(char a[])
{
char *p=a,*q=a,c;
int i;
while(*p!='\0')
p++;
p--;//此刻p指向最后一個元素
while(p>q)
{
c=*p;
*p=*q;
*q=c;//交換對稱位置的字符值
p--;
q++;
}
}
int main()
{
char a[100];
scanf("%s",a);
reverse(a);
printf("%s",a);
return 0;
}
補充:C語言 將字符串轉(zhuǎn)化成整數(shù),正序(逆序)輸出
字符串轉(zhuǎn)化為數(shù)字:—‘0'
數(shù)字轉(zhuǎn)化為字符串:+‘0'
#include <stdio.h>
#include <stdlib.h>
#include <vld.h>
#include <assert.h>
#include <ctype.h>
#include <string.h>
void Reverse(char *str) //逆序
{
char *p = str;
while(*p != '\0') //找到\0
{
p++;
}
p--; //\0前一位
int temp;
while(str < p)
{
temp = *str; //交換
*str = *p;
*p = temp;
str++;
p--;
}
}
int Myatoi(const char *str) //字符串轉(zhuǎn)化為數(shù)字
{
assert(*str != NULL);
int sum = 0;
while(isdigit(*str))
{
sum = sum*10+*str-'0';
*str++;
}
return sum;
}
void Myitoa(char *str,int n) //數(shù)字轉(zhuǎn)化為字符串
{
assert(*str != NULL);
int i = 0;
do{
str[i++] = n % 10 + '0';
n /= 10;
}while(n != 0);
str[i] = '\0';
// Reverse(str);
}
int main()
{
char str1[100] = "1a2";
printf("num = %d\n",Myatoi(str1));
char str[100];
Myitoa(str,1235496);
printf("str = %s\n",str);
return 0;
}

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
Qt數(shù)據(jù)庫應用之實現(xiàn)通用數(shù)據(jù)庫采集
這篇文章主要為大家介紹了Qt中是如何實現(xiàn)通用數(shù)據(jù)庫采集的,文中的示例代碼講解詳細,對我們學習Qt有一定幫助,感興趣的小伙伴可以了解一下2022-03-03
詳解應用程序與驅(qū)動程序通信DeviceIoControl
這種通信方式,就是驅(qū)動程序和應用程序自定義一種IO控制碼,然后調(diào)用DeviceIoControl函數(shù),IO管理器會產(chǎn)生一個MajorFunction為IRP_MJ_DEVICE_CONTROL,MinorFunction為自己定義的控制碼的IRP,系統(tǒng)就調(diào)用相應的處理IRP_MJ_DEVICE_CONTROL的派遣函數(shù)2021-06-06
詳解C++中的函數(shù)調(diào)用和下標以及成員訪問運算符的重載
這篇文章主要介紹了詳解C++中的函數(shù)調(diào)用和下標以及成員訪問運算符,講到了這些二元運算符使用的語法及重載,需要的朋友可以參考下2016-01-01
解析如何用指針實現(xiàn)整型數(shù)據(jù)的加法
本篇文章是對用指針實現(xiàn)整型數(shù)據(jù)加法的方法進行了詳細的分析介紹,需要的朋友參考下2013-05-05
C++數(shù)據(jù)結(jié)構(gòu)哈希表詳解
C++標準庫中使用的unordered_map底層實現(xiàn)是哈希表,下面這篇文章主要給大家介紹了關(guān)于C++中使用哈希表(unordered_map)的一些常用操作方法,需要的朋友可以參考下2022-07-07

