當前位置:首頁 » 編程語言 » c語言刪除重復字元並排序後輸出
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

c語言刪除重復字元並排序後輸出

發布時間: 2022-07-21 04:29:35

❶ (c語言)輸入一串字元,按從小到大順序排列並刪除重復項。

#include<stdio.h>
#include"string.h"
int main(void)
{
char str1[500]={0},str2[256]={0};//定義二個數組,並賦初值為0
int i;
gets(str1);//讀取一個字元串
for(i=0;str1[i];i++)
{
str2[str1[i]]=1;//str1中每個字元的assic碼作為str2的下標值,並把對應位置填充為1,同一個字元的assci值相同,所以這樣就去掉了重復字元
}
for(i=0;i!=256;i++)
if(str2[i]==1)//判斷數組中被str1填充的位置,填充的是非0值,沒填充的是0值
printf("%c",i);//輸出str2的下標值,對應str1中的字元值
putchar('\n');
return 0;
}

❷ #c語言編程#實現將字元串中所有重復的字元剔除,將剔除之後的輸出 如sajsk輸出ajk

#include <stdio.h>
#include <string.h>

void sort(char s[]) { // 選擇排序
int i,j,k,t,len = strlen(s);
for(i = 0; i < len - 1; ++i) {
k = i;
for(j = i + 1; j < len; ++j) {
if(s[k] < s[j]) k =j;
}
if(i != k) {
t = s[i];
s[i] = s[k];
s[k] = t;
}
}
}

// 將不重復的字元復制到t[],返回刪除的字元個數
int change(char s[], char t[]) {
int i = 1,j = 0,cnt = 0;
sort(s);
t[0] = s[0];
while(s[i]) {
if(s[i] == s[i - 1]) ++cnt;
else t[++j] = s[i];
++i;
}
t[j] = '\0';
return cnt;
}

int main() {
char s[] = "aseqkwh wkqhasweewwqbkh112504ffvsdr";
char t[60];
printf("原串:%s\n",s);
printf("共刪除%d個字元。\n",change(s,t));
printf("最後得到的字元串為:%s\n",t);
return 0;
}

❸ C語言去掉重復字元再排序

char a[30] = "qweasdzxcvbnhbgfvredcxswqazx";
for (int i = 0; i < 30; i++) {

printf("%c",a[i]);

for (int j = 0; j < i; j++) {

if (a[i] == a[j]) {

a[i] = '0';

}

}

}printf("\n");

for (int i = 0; i< 30; i++) {

if (a[i] != '0') {

printf("%c",a[i]);

}

}
用兩個for循環,將字元串的每一個字元和前一個進行比較,如果有一個相同,將他等於字元串內不同的一個字元(很重要),然後另作一個for循環,將不含有這個字元的字元串輸出
qweasdzxcvbnhbgfvredcxswqazx

qweasdzxcvbnhgfr

還給你一個方法,先排序,然後將,a[i]==a[i+1]的時候,將a[i]='0',也可以做出來,但是位置變化了

❹ C語言中刪除字元串中的重復字元,然後輸出新的字元串

#include<stdio.h>
#include<string.h>
intmain()
{
charc,str[80];
inti=0,j,k,len;
printf("input:");
gets(str);
len=strlen(str);
c=str[i];
while(c!='')
{
for(j=i+1;str[j]!='';j++)
{
if(str[j]==c)
{
for(k=j;str[k]!='';k++)
str[k]=str[k+1];
len--;
}
}
c=str[i++];
}
puts(str);
getchar();
}

改動後可以運行了,你的錯誤:
1.包含的第二個頭文件少寫個h
2.在發現重復字元後需要刪除時,if語句里for循環使用了j和外面大循環的j重復,會造成不可預料的錯誤
3.else後面的賦值不正確,應該等第一個for循環結束後,而不是if判斷後

❺ C語言編程:從鍵盤輸入一個有空格的字元串,刪除所有重復字元,按字元升序輸出在屏幕上。怎麼做

代碼文本:

#include "stdio.h"

int main(int argc,char *argv[]){

char a[101],*p,*px,t;

printf("Input a string... ");

for(p=a,t=0;t<100;t++)//輸入字元串

if((*(p+t)=getchar())==' ')

break;

*(p+t)='';

for(p=a;*p;p++)//排序

for(px=p+1;*px;px++)

if(*p>*px){

t=*p;

*p=*px;

*px=t;

}

for(p=a;*p;p++){//刪除重復字元

for(t=1;*p==*(p+t);t++);

if(t>1){

for(px=p;*px=*(px+t);px++);

p--;

}

}

printf(*a ? " %s " : " (null) ",a);//輸出

return 0;

}

供參考。

❻ 求C語言代碼,刪除字元串中重復字元 如輸入"aabbcc",要求輸出"abc"

字元也可以使用整數來表示,其實整數0-255用%c來輸出就是字元。
#include <stdio.h>
int main() {
char s[256]; /*初始化了一個數組來存放輸入的串*/
int i = 0, tmp[256] = {0}; /*tmp是一個256個整型數組,初始化成全0*/
printf("Enter the string :\n");
gets(s); /*將輸入的串存到s中*/

/*分析每個輸入的字元,如果字元是'a' 則a=97,那麼 tmp[97]將置成1 ,如果下一個字元串還是
'a',那麼同樣tmp[97]置成1,如果下一個字元是'b',那麼tmp[98]將置成1......*/
while(s[i] != '\0')
tmp[s[i++]] = 1;

puts("\nAfter sort and delete operation:");
/*順序輸出255個字元中s串中包含的字元*/
for(i = 0; i < 256;i++)
if(tmp[i])
printf("%c", i);
return 0;
}

那麼等於是說全部ascii字元集是256個,如果有哪個字元那麼就把它標記上,然後再從0開始順序輸出就可以了。

❼ c語言刪除字元串中重復的內容並排序

//刪除字元串中重復的字元並排序
#defineN6
#include<stdio.h>
main()
{ //定義變數

inti,j,k,n=0;
charch[100],t;

//輸入

for(i=0;i<N-1;i++)
scanf("%c",&ch[i]);

//刪除重復字元

for(i=0;i<N-1-n;i++)
{
for(j=0;j<i;j++)
{
if(ch[i]==ch[j])
{
for(k=j;k<N-1-n;k++)
ch[k]=ch[k+1];
j--;
n++;
}
}
}

//輸出(無重復字元)

k=N-n-1;
for(i=0;i<k;i++)
printf("%c",ch[i]);
printf(" ");

//排序(冒泡法)

for(i=0;i<k-1;i++)
{
for(j=0;j<k-1-i;j++)
{
if(ch[j]>ch[j+1])
{
t=ch[j];
ch[j]=ch[j+1];
ch[j+1]=t;
}
}
}

//輸出(無重復字元並排序)

for(i=0;i<k;i++)
printf("%c",ch[i]);
printf(" ");

//結束

return0;
}

❽ c語言排序後刪除數組中重復的數字再排序輸出

#include<stdio.h>

#include<string.h>

#defineSIZE81

voiddelete_repeat(char*str);

voidbubble_sort(char*str);

intmain()

{

charstr[SIZE];

gets(str);

delete_repeat(str);

bubble_sort(str);

puts(str);

return0;

}

//刪除重復字元

voiddelete_repeat(char*str)

{

/**判斷數組內第i個字元是否與前i-1個字元存在重復:

若重復,刪除該字元,i之後的字元下標均減1,後重新判斷新的第i個字元

若不重復,不做處理,繼續遍歷下一個

*/

for(inti=1;str[i]!='';i++){

for(intj=0;j<i;j++)

{

if(str[i]==str[j])

{

for(intk=i;k<strlen(str)-1;k++)

{

str[k]=str[k+1];

}

str[strlen(str)-1]='';

i--;

}

}

}

}

//冒泡排序

voidbubble_sort(char*str)

{

intswap;

chartemp;

intk=strlen(str);

do{

swap=0;

for(inti=0;i<k-1;i++){

if(str[i]>str[i+1])

{

swap=1;

temp=str[i];

str[i]=str[i+1];

str[i+1]=temp;

}

}

k--;

}while(k>0&&swap);

}

(8)c語言刪除重復字元並排序後輸出擴展閱讀

刪除排序數組中的重復項注意事項

不要使用額外的數組空間,必須在原地修改輸入數組並在使用O(1)額外空間的條件下完成,意味著不能通過新建數組存放的方式解決。

可以考慮增加一個游標的方式(命名為:index),遍歷整個數組,當遇到前一個和後一個不相等的時候就給游標自增,這樣的話對於相同的元素可以直接跳過不統計,最後返回」游標的大小+1「(也即不重復的元素的個數)。