欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言 將字符串逆序輸出的實(shí)例

 更新時(shí)間:2021年02月20日 09:42:01   作者:咕嘟咕嘟520  
這篇文章主要介紹了C語(yǔ)言將字符串逆序輸出的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧

將字符串逆序輸出:我先說一個(gè)我的錯(cuò)誤代碼,一開始真的不知道哪里錯(cuò)了,但是當(dāng)時(shí)的想法是自以為是可以的,大家可以先看看我的錯(cuò)誤代碼

這個(gè)代碼是錯(cuò)誤的,正確的在最下方,不要急,我只是展示一下自己的錯(cuò)誤,哈哈

#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指向最后一個(gè)元素
//  while(p>q)
//  {
//    c=*p;
//    *p=*q;
//    *q=c;
//    p--;
//    q++;
//  }
  i=0;
  for(i=0; p>=q; i++)
  {
    a[i]=*(p);//代碼就是這里出的錯(cuò),在下面解釋一下
    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;
}

上面代碼:我一開始想著,定義一個(gè)指針p,然后先將指針指向最后一個(gè)元素,然后慢慢往回(前面)指,再將指針p指向的值賦給a[i],i從0開始變化,這個(gè)想法其實(shí)沒有錯(cuò),但是卻忽略了,指針只有改變地址的權(quán)利,而賦值則是將字符串完全改變了,那么指針一開始指向中間靠后的值的時(shí)候,原來a字符串里面中間靠前的字符就會(huì)改變(因?yàn)槭悄嬷x值的),那么到了指針p指向中間靠前的時(shí)候,p指的是已經(jīng)變化過的a中的字符值啦。

那么問題來了,怎樣做呢,將對(duì)稱位置的字符交換即可。

下面是正確代碼,比較簡(jiǎn)單,不做過多介紹啦

#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指向最后一個(gè)元素
  while(p>q)
  {
    c=*p;
    *p=*q;
    *q=c;//交換對(duì)稱位置的字符值
    p--;
    q++;
  }
}
int main()
{
  char a[100];
  scanf("%s",a);
  reverse(a);
  printf("%s",a);
  return 0;
}

補(bǔ)充:C語(yǔ)言 將字符串轉(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;
}

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

相關(guān)文章

  • C++實(shí)現(xiàn)多線程查找文件實(shí)例

    C++實(shí)現(xiàn)多線程查找文件實(shí)例

    這篇文章主要介紹了C++實(shí)現(xiàn)多線程查找文件實(shí)例,對(duì)于深入學(xué)習(xí)C++程序設(shè)計(jì)有著很好的參考借鑒價(jià)值,需要的朋友可以參考下
    2014-10-10
  • C++實(shí)現(xiàn)LeetCode(90.子集合之二)

    C++實(shí)現(xiàn)LeetCode(90.子集合之二)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(90.子集合之二),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • ON_COMMAND_RANGE多個(gè)按鈕響應(yīng)一個(gè)函數(shù)的解決方法

    ON_COMMAND_RANGE多個(gè)按鈕響應(yīng)一個(gè)函數(shù)的解決方法

    這篇文章主要介紹了ON_COMMAND_RANGE多個(gè)按鈕響應(yīng)一個(gè)函數(shù)的解決方法,需要的朋友可以參考下
    2014-07-07
  • 最新評(píng)論