A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 刘旭升 高级黑马   /  2014-1-1 11:53  /  1592 人查看  /  5 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

  1. public class Shuzu {
  2.         public static void main(String[] args){
  3.                 int[] arr = new int[]{2,2,2,4,5,7,98,4};        //旧数组;
  4.                 int[] arr1 = new int[]{2,2,2,2,2,2,2};                                        //新数组;
  5.                 boolean flag=true;int index=0;                        //初始化布尔值和角标值;
  6.                 for(int i=0;i<arr.length;i++){                        //外圈:轮流取得旧数组的值;
  7.                         for(int j=0;j<arr1.length;j++){                //内圈:比较外圈值在内圈是否存在;
  8.                                 if(arr[i]==arr1[j]){
  9.                                         //如果旧值等于新值,那么就让布尔为false,控制新数组装数打印。
  10.                                         flag=false;
  11.                                         }
  12.                                 }
  13.                         while(flag){                System.out.print(arr[i]);                                //新数组装数,仅当旧值不等新值时;
  14.                                 arr1[index]=arr[i];       
  15.                                 //if(index==8)
  16.                                         //index=8;//装数
  17.                                 //else index++;
  18.                                 index++;
  19.                                 }
  20.                         }
  21.                         for(int n=0;n<index;n++)                        //遍历,打印。
  22.                                 System.out.print(arr1[n]+"  ");
  23.         }       
  24. }
复制代码
新书组装不重复的旧数组元素、、怎么搞,上面代码有什么问题?流程说下?灰常感谢.感谢你一辈子...

评分

参与人数 1技术分 +1 收起 理由
FFF + 1 淡定

查看全部评分

5 个回复

倒序浏览
楼主想实现什么功能?出现什么问题说下
回复 使用道具 举报
楼主是要实现什么功能都不明确
回复 使用道具 举报
从代码看,第一个问题是boolean声明的位置错误,应当声明在第一个for循环也就是外层循环内
第二个问题是arr1[index]=arr,比如当循环到arr[3]=4时,会把arr1[0]赋值成4,也就是arr1[0]=4,当循环到arr[7]=4时,在内层循环中比较时,arr[7]=arr1[0],都等于4,所以flag被赋值成false
解决代码如下:

  1. public static void main(String[] args)
  2. {
  3.         int[] arr = {2,2,2,4,5,7,98,4};                       //旧数组;
  4.         int[] arr1 = {2,2,2,2,2,2,2};                         //新数组;
  5.         int[] arr2 = new int[arr.length];                                          //新增数组
  6.         int index=0;                                          //初始化布尔值和角标值;
  7.         for(int i=0;i<arr.length;i++)                         //外圈:轮流取得旧数组的值;
  8.         {
  9.                     boolean flag=true;
  10.                 for(int j=0;j<arr1.length;j++)                //内圈:比较外圈值在内圈是否存在;
  11.                 {                                            
  12.                         if(arr[i]==arr1[j])
  13.                         {
  14.                                 flag=false;
  15.                                 break;
  16.                         }
  17.                 }
  18.                 if(flag)
  19.                 {               
  20.                         System.out.print(arr[i]+" ");                 //新数组装数,仅当旧值不等新值时;
  21.                     arr2[index]=arr[i];        
  22.                     index++;
  23.                 }
  24.         }
  25.         
  26.         for(int n=0;n<index;n++)                               //遍历,打印。
  27.                         System.out.print(arr2[n]+"  ");
复制代码

评分

参与人数 1技术分 +1 收起 理由
FFF + 1 赞一个!

查看全部评分

回复 使用道具 举报
public class Shuzu
{
        public static void main(String[] args)
        {
                int[] arr = new int[]{2,98,4};//旧数组;
        int[] arr1 = new int[]{2,2}; //新数组;
        int[] arr2 = new int[arr1.length+arr.length];
        System.out.println(arr[1]);
        
        boolean flag = true;
        int index=0;                        //初始化布尔值和角标值;
        for(int i=0;i<arr.length;i++)
        {
               
                for(int j=0;j<arr1.length;j++)
                {               
                        //内圈:比较外圈值在内圈是否存在;
                if(arr[i]==arr1[j])
                        flag=false;//如果旧值等于新值,那么就让布尔为false,控制新数组装数打印。
                else
                        flag = true;
                //System.out.println(flag);
             }
                if(flag)
                {               
                        //System.out.println(arr[i]); //新数组装数,仅当旧值不等新值时;
                        arr2[index++]=arr[i];
                }
        }
        for(int j=0;j<arr1.length;j++)
            {
                System.out.println(index);
                arr2[index++]=arr1[j];
            }
        
        
        for(int n=0;n<index;n++)//遍历,打印。
                System.out.print(arr2[n]+"  ");
        }        
}
回复 使用道具 举报
刚才的代码没修改好
public class Shuzu
{
        public static void main(String[] args)
        {
                int[] arr = new int[]{2,98,4};//旧数组;
        int[] arr1 = new int[]{2,2}; //新数组;
        int[] arr2 = new int[arr1.length+arr.length];
        
        boolean flag = true;
        int index=0;                        //初始化布尔值和角标值;
        for(int i=0;i<arr.length;i++)
        {
                for(int j=0;j<arr1.length;j++)
                {               
                        //内圈:比较外圈值在内圈是否存在;
                if(arr[i]==arr1[j])
                        flag=false;//如果旧值等于新值,那么就让布尔为false,控制新数组装数打印。
                else
                        flag = true;
             }
                if(flag)
                {               
                        //新数组装数,仅当旧值不等新值时;
                        arr2[index++]=arr[i];
                }
        }
        //把arr1的值放到arr2里面
        for(int j=0;j<arr1.length;j++)
            {
                arr2[index++]=arr1[j];
            }

        for(int n=0;n<index;n++)//遍历,打印。
                System.out.print(arr2[n]+"  ");
        }        
}
判断条件应该用if,还有数组长度是固定的,创建好了就不能修改了

评分

参与人数 1技术分 +1 收起 理由
FFF + 1 赞一个!

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马